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PREFACE 


This document describes hardware aspects of the 

MEMOREX 7200/7300 Computers at the design level 

of March, 1972. It completely replaces the pre- 
vious versions. 


This product description contains information for 
programmers, engineers, field support and marketing 
personnel, and other Memorex personnel concerned 
with a general overview of the processor's capabil- 
ities of the computer; discuss its functional 
characteristics and principles of operation, in- 
cluding instruction descriptions, and describe the 
System Control Panel and its use. 


It is recognized that changes are occurring, and 
potential changes are being evaluated; present 
and future inaccuracies will be treated in later 
publications. 


The Product Description is intended to serve as 

a source of official information for Memorex 

personnel until it is supplanted by the series 

of 7200 and 7300 Computer manuals now being generated. 
Comments may be sent to the Publications Department, 
Midwest Operations, Memorex Corporation, 9200 

Science Center Drive, Minneapolis, Minnesota, 55428, 
for use in preparing these future publications. 
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SPECIAL MRX MARKETING EDITION 


This abridged edition of the 7200/7300 computers Product Description 
has been prepared from more extensive Memorex internal development 
documentations. 
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SECTION I 
GENERAL DESCRIPTION 


INTRODUCTION 


An overview of the MRX/40/50 data-processing systems is provided in Sec- 
tion 1 of this product description. The remainder of this manual is 
devoted to the detailed description of the functional and logical charac- 
teristics of the MEMOREX 7200 and 7300 computers. Appendix A tabulates 
the performance differences between the 7200 and 7300. While peripheral 
devices are referred to throughout, they are not discussed in detail. 


The MRX/40 and 50 are low-cost communications~oriented systems with 

large data base capacity. A wide range of storage sizes, peripheral 
devices, and integrated adapters affords maximum flexibility in tailoring 
a system to meet a user's specific need. MRX/40/50 are supported by an 
unusually comprehensive operating system developed by Memorex. This 
extensive programming systems Support permits the user to concentrate 

on his application, rather than on the functions of the system. The 
combination of hardware and software capability provides a price/per- 
formance level normally associated with more costly data processing 
systems. The result is a more efficient and economical data-processing 


system for the user. 

Several sieaeeaieties distinguish the MRX/40/50 computer systems: 
e@ Advanced architecture 
@ Wide range of peripheral devices 
@ Extensive communications support 


@ Comprehensive programming systems support 
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ARCHITECTURE 


The MEMOREX 7200 and 7300 offer advanced hardware design at all levels, 
from monolithic circuit components to architecture. The use of mono- 
lithic components produces a high-speed machine cycle. Miniaturized 
circuits permit the concentration of great computational power in a 
physically small cabinet. They also reduce the number of required 
components, thus decreasing the potential sources of hardware failure; 
the result is a high degree of reliability. The 7200/7300 printed- 
circuit boards are packaged and arranged by function, which makes fault 
isolation and correction faster. 


Main storage is implemented through the use of metal-oxide semi- 
conductors (MOS) which allow for greater packing density of components 
and lower memory costs. Storage sizes of the 7200/7300 range from 

16K to 128K bytes (each byte contains 8 bits plus a parity bit). 


The 7200 and 7300 are microprogrammed computers. All machine language 
instructions are implemented through the use of microprogramming instruc- 
tions residing in Control Storage. These micro-instructions perform 
within the much shorter cycle time of Control Storage. Microprograms, 
automatically loaded at Initial Program Load (IPL) time, are provided by 
Memorex; they reside as a small reserved portion of a disc pack and 
require no user intervention or maintenance. 


The design of the 7200/7300 computers is such that certain portions of 
the hardware are dedicated to specific functions such as communications 
input-output, direct-access input-output, and arithmetic functions. A 
full set of eight general registers is dedicated for each such use by 
the operating system. Three additional sets of eight general registers 
are dedicated for user programs. The use of these various hardware 
functions is controlled by the operating system which interfaces to a 
hardware-controlled priority network. 


The 7200/7300 incorporate integrated adapters for control of disc 
storage, communications, card readers, and card punches. Their use 


eliminates the need for large external control units, and thus provides 
for a lower-cost system. 


7200/7300 computer features include these: 
e Alterable Control Storage (4K words) 
@ Up to128K bytes of Main Storage 


e rror Correction Code (ECC) option for Main 
Storage 


© Job Accounting Aids 


r) Interval Timer 
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@ Storage Protection 
-@ Relocation and Protection 
® Integrated Console Adapter (standard) 


@ Integrated Communications Adapter (ICA) servicing up 
to 15 communications channels 


® Integrated File Adapter (IFA) for up to eight MEMOREX 
3664 disc drives. 


@® Integrated adapters for the following: 


- up to 1000 cpm card readers (80-column) 
- up to 500/120 cpm reader/punch (80-column) 


® Printer attachment for up to 1200 Ipm printer 


#® Up to two selector channels for supporting external 
control units. 


PERIPHERAL DEVICES 


An unusually wide range of peripheral devices to solve a variety of 
application needs can be accommodated by ‘the MRX/40/50 systems: 


® Card equipment (80-column esa. 

e Printers may range in speed up to 1200 lines per minute. 

e From one to eight disc drives may be used, each with a 
capacity of 14 or 28 megabytes. This adds up to a 


potential of 224 million bytes of on-line storage. 


@ Magnetic tape transfer rates may be up to 60 kilobytes 
per second. 


COMMUNICATIONS SUPPORT 


The MRX/40/50 systems have low-cost communications hardware, combined 
with simplified communications software. Up to 15 communications lines 
are provided for operations in asynchronous or synchronous modes. Other 
features include autocall, autoanswer, speed selection, autopoll, station 
select, and synchronous transparency. 
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For terminals, the user may choose from the MEMOREX 1200 series or 
certain IBM* and Teletype* terminals. Networks ranging from small to 
relatively large may be configured for the MRX/40/50. 


A logical-level macro language is provided to handle both asynchronous 
and synchronous transmissions. Included are the standard functions 
such as READ, WRITE, GET, PUT, and code translate. Messages are 
queued in memory. A special communications monitor controls multiple 
terminals and multiple transactions for the user-written application 
programs. 


PROGRAMMING SYSTEMS SUPPORT 


The MRX/40/50 systems are supported by a level of programming systems 
normally only available with large-scale systems. The operating system 
provided for the MRX/40/50 is a comprehensive multi-programming system 
which includes the following features: 

e Cataloged job control statements 

e Input spooling 

® Output spooling 

@ Complete data management 

@e Extensive utility programs 

e High-performance disc sort 

e Advanced library facilities 

e Modular systems generation 

@e IBM* System/360 Model 20 compatibility 
Four major programming languages are available for MRX/40/50: Assembler, . 
ANSI COBOL, RPG I|1 and FORTRAN IV. The Assembler language has complete 
macro capability. COBOL includes many significant extensions. The 
RPG II language is designed so that most IBM 360/20 and System/3 
programs will recompile and execute without modification. Al] languages 


include the ability to exit to assembler language subroutines, and 
programs can be segmented. 


*Tradenames, International Business Machines Corporation and the Teletype 
Corporation. 
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INTRODUCTION 


This section contains information intended to provide program imp]emen- 
tation understanding for the MRX/40/50 system (MEMOREX 7200 and 7300 
computers respectively). It does so by further explaining the system 
architecture (hardware and software concept and relationship) and de- 
scribing data and instruction formats, storage addressing, and princi- 
ples pertinent to program implementation. 


SYSTEM ARCHITECTURE 


” 


Data processing systems divide their time between input/output operations 
and arithmetic/logical functions. This conflict of Interest usually 
causes large periods of system time to be dominated by input/output 
functions. Obviously, while this domination exists, hardware such as 
that dedicated to arithmetic/logical functions stands idle. This results 
in uneconomical time-versus-hardware usage. 


To avoid this uneconomical usage, the 7300 computer employs a multiplex 
technique which divides one complete machine cycle into eight segments 
called ''major cycles''. Along with this time division, a design concept 
is implemented dedicating those resources (hardware) which are function 
oriented to one of these time segments. Figure 2-1] illustrates this 
combination of one major cycle and a particular set of dedicated 
resources as a ''processor state''. These processor states are 
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Figure 2-1. System Architecture 
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functionally oriented and during the time they exist have exclusive 
access to what is termed ''shared resources''. Shared resources are 
those elements of hardware, such as an arithmetic section, which are 


‘common to all processors. 


Input/Output 


The first consideration in any data-processing system is how well it 
can transmit or receive data. As shown in Figure 2-1, the 7300 compu- 
ter has functionally oriented integrated adapters and hardware as 
described by the following paragraphs. 


e There is an integrated communications adapter capable 
of controlling up to 15 independent communications 
lines. These communications lines are connected 


through the adapter to the communications processor. 


The integrated adapter (!IXA) for the system console 
also uses the communications processor. 


@ There are two basic data channel processors. 

1. The card reader, card reader/punch, and printer 
connect to the basic data channel via their 
respective adapters. Up to seven external 
control units connect to the basic data channel 
via the first selector channel option. 


2. Up to eight additional external control units 
may be attached to the second selector 
channel. 


@e To accommodate disc storage devices, an integrated file 
adapter is provided connecting up to eight disc drives 
to the disc processor. 


Computer Hardware 
. \ 
Each of the four input/output processors has a set of general registers. | 


These registers are used by the input/output routines for thelr respec- 


tive function. 


Four additional sets of general registers are Illustrated in Figure 2-1. 
One of these register sets is dedicated to the control programs of the 
operating system. The remaining three sets of general registers are 
dedicated to executing user programs. 
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Hardware timing for the 7300 computer divides the total computer cycle 

into eight segments (major cycles). During each major cycle, specific 

functionally dedicated resources (hardware) perform in conjunction with 
shared resources to become a processing entity. Figure 2-1 illustrates 
this period of time as a ''processor state'’. One of these major cycles 

is allotted to each processor state. 


Priority 


As previously mentioned, the hardware machine timing is divided into 
major cycles, allocated one cycle per processor state. Figure 2-1 
illustrates the first major cycle being allocated to processor state 

0 (communications processor). In other words, for that cycle the com- 
puter is operating the communications hardware. During the next major 
cycle, processor state 1 (a multi-device processor) hardware is in 
operation. This continues through processor states 2, 3, 4, 5, 6, 

and 7. 


If, as the diagram shows, all processor states have work to perform of 
equal priority, these cycles occur sequentially. Processor states per- 
forming high-speed input-output operations need priority over those 
performing lower-speed input-output or general computational functions. 
For this purpose, a priority scheme is provided to take care of any 
1/0 processor state that needs major cycles sooner than its normal 

turn in the sequence. This priority scheme can be adjusted at the end 
of each major cycle; that is, every major cycle a test is made to see 
if the normal priority (sequential processor-state operation) is to be 
followed, or if an 1/0 processor should be given an out-of-sequence 
cycle. This action is similar to that of a system that operates on a 
priority-interrupt system. 
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Storage Protection 


This feature provides main storage protection for each of the processor 
states 5, 6, and 7. A register designated Upper Bounds (UB) and Lower 
Bounds (LB) is provided for each of these processor states. These 
registers are accessible only by processor state 4. 


Upper and Lower Bounds values are set up by the control program 
(processor state 4). Each writing access attempted by an instruction 
executing under processor states 5, 6, or 7 is then checked by the 
Storage Protection hardware against the UB and LB values for that 
processor state. If the address falls outside the bounds values, writing 
is prevented and the control program detects a problem program addressing 
error. 


Computer Options 


The following paragraphs describe optional features of the 7300 com- 
puter. 


JOB ACCOUNTING 


This option comprises eight 32-bit registers, one for each processor 
State, and an incremental adder. Each time a processor state gets 

a major cycle, the hardware automatically increases the contents of 
the associated Job Accounting register by 1. A job accounting regis- 
ter may be read at any time, but any attempt to write into it will 
reset it to zero. 


RELOCATION AND PROTECTION 
The Relocation and Protection feature provides three functions: 


1. Allows for relocation of programs without instruction 
modification 


2. Extends the addressing capability of the system from 
65K to up to one-million bytes 


3. Provides a comprehensive storage protection scheme 
for all processor states, 


This feature is implemented through the use of a Segment Relocation 
Table, Protection Matrix, Segment Tag File, and Address Mode Register. 
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Relocation. Each processor state has a hardware ''segment tag'' associated 
with its program address (P) register and with each of its general 
registers. This segment tag identifies an entry in the Segment Re- 
location Table, from which a relocation constant or lower boundary page 
number of the storage segment (or block) is obtained. Each entry in 

the Segment Relocation Table also contains an upper boundary number 

for that segment. 


The effective address presented by each processor to the relocation 
and protection hardware is called the system address. The 20-bit 
system address consists of two parts: a 4-bit Segment Number and a 
16-bit displacement within the segment. The displacement consists 
of an 8-bit Page Number (identifying blocks of 256 bytes each) and 
an 8-bit byte displacement. 


The relocation and protection hardware uses the segment tag for access 
to the appropriate entry in the Segment Relocation Table. The 16-bit 
displacement is then added to the relocation constant to form the 
physical memory address used in the instruction. (The 8-bit displace- 
ment is never altered. Figure 2-2.) 


The general rule for obtaining a Segment Number is this: if there is a 
general register involved in the formation of the address, its 
associated segment tag is used; if there is no general register so 
involved, the segment tag associated with P-Register is supplied. 


Protection. Storage may be divided into a maximum of 16 segments; 
access to each is controlled through the Protection Matrix. This 
matrix is organized as shown in Figure 2-3. Each processor has two 
rows assigned to it; one for READ and one for WRITE. Access by a 
processor state for READ or WRITE to a specific segment is allowed 
only if the bit is 0 in the column for the correct segment corres- 
ponding to the row for that processor state. 


if access is to be permitted, a check is also performed by the relo- 
cation and protection hardware to assure that the page number of the 
system address displacement does not exceed the ''upper bounds'' entry 
in the Segment Relocation Table for that segment. ''Upper bounds'' is 
the maximum page number which may be addressed within that segment. 
If the bounds is exceeded, the instruction will not be executed and a 
condition code will be set for the processor state. 


Control. Control of the Relocation and Protection feature is supported 
through special machine language instructions and the Address-Mode 
Register. Access to these is controlled by the control program (proc- 
essor state 4). 
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System Address 


Segment Ta Displacement 


OA 


Segment Relocation Table 


Used only during 
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Physical Memory Address 


0 04 OA 


Figure 2-2, Generating Relocation Address 
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SEGMENT NUMBER 
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Storage Access Protection Matrix 


Figure 2-3. 
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ERROR CORRECTION CODE OPTION 


The Error Correction Code (ECC) option corrects single-bit errors, and 
detects but does not correct double-bit errors made during a storage 
reference. In either case, an entry is made in the ECC Error Log 
register. 


DATA REPRESENTATION 


The basic unit of memory for the MEMOREX 7300 processor is an 8-bit byte. 
The bytes in memory are numbered from 0 to a maximum of 131,072 (128K) . 
The computer transfers two bytes at a time into or out of memory; these 
two bytes are treated as a unit, called a word. The bits in a byte or 
word are numbered left to right from 0 through 7 or 0 through 15, 
respectively. 


Byte Oo 7. 2) °3> 4% 6. B.7 


a es ee ee ey eS es ee 


Data can be represented in any of the following formats: hexadecimal, 
EBCDIC, binary, and zoned or packed decimal. 


Word 


Hexadecimal Representation 


Hexadecimal notation is a system in which four bits are used to represent 
the decimal values, 0-15. Since the hexadecimal system implies 16 differ- 
ent numbering symbols, this system uses digits 0-9 and letters A. B.C 
D, E, and F for decimals 10, 11, 12, 13, 14, and 15, respectively, a 
Each hexadecimal symbol has a corresponding 4-bit pattern. This system 
uses every possible combination of the four bits (16 combinations) 


For example, the value of each of four bits is sh 
j Own, represent h 
equivalents of 23, 22, 2!, and 29, 2TEP ing the 


8 | 
: 
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> 
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lt 

wn 


8+44+2+] F 


The following table shows the correlation between decimal, hexadecimal, 
and binary notation. 


Decimal Hexadecima| Binary 
0 0 0000 
l ] 0001 
2 2 0010 
3 3 0011 
4 mn 0100 
a 5 0101 
6 6 0110 
7 us O11) 
8 8 1000 
9 2 100] 

10 A 1010 
1] B 1011 
IZ C 1100 
13 D 110] 
14 E 1110 
15 F 11] 


Using hexadecimal notation, a direct conversion from binary to hexadec- 
imal, or vice-versa, is very easily made. 


Hexadecimal] 9 8 E B 


i Ee ee eee 
Binary Lt] 0 | 0 Pe fo fo fofi fi fr foft oP] 


EBCDIC Representation 


Extended Binary-Coded-Decimal Interchange Code is a system that uses an 
8-bit code to represent 256 possible characters (256 possible variations 
of eight bits). The EBCDIC system not only represents digits 0-9, but 
also the letters of the alphabet (upper and lower case), all punctuation 
and arithmetic symbols (such as + - ; > =), and some special graphic and 
control symbols (such as SMM- start of manual message, and EOT - end of 
transmission). 
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Each character (letter, digit, or other symbol) is represented in one byte 
(eight bits). The byte is divided into two portions of four bits each: 


Lea ies 


a 


Bits 0-3 Bits 4-7 


Some examples of EBCDIC characters and their corresponding 8-bit codes 
are: 


noooooom 
TPT TPP]: 
DOO0GGGo ee 


U 
> 


If 
\o 


= ECT (end of transmission) 


Numeric fields in EBCDIC are in a zoned decimal format. 


The following chart shows the entire set of EBCDIC symbols with the 
hexadecimal equivalents of the zone and digit portions. 
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Representation 


Bits 4-7 
Hexadecima | 
and Binary 

Representation 


li nike arena onal a aa st ca oe ree ae 


Peete ee oe ae eee 
wi GN CA 


3 001) CU3 |DC4 |NAK 


4 0100] SP 


LL Trice tT 
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Binary Representation 


A word (two bytes) in a signed binary format has a sign bit (bit 0) and 
15 bits in which to hold a value (bits 1-15). The value of each bit 
increases from right to left by a power of two. 


0 | | 15 
Na re ee eee I RE ee, SE ee OEY | 
EE EEE 


Pan These two bytes can hold a signed 


ra binary value ranging from -32,768 to +32,767 
=minus | 


To determine the decimal value of a binary field, the decimal equivalents 
are added for each bit position that is on (1). 


0 


LS 
lo fofofofofolifolo]i Tetolo Tiley] 
29 2 22 2 


27 = 612 512 
26 = 64 64 
22 = 4 \ 
20 = | 1 
581 = decimal value of field 
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Positive numbers are in the format described in the preceding text; each 
bit position stands for a specific value. Negative numbers are in a 
two's complement form. The two's complement of a value is formed by 
reversing the state of each bit (this is the one's complement form) 
and then adding 1 to the entire field(this is the two's complement form). 


) 15 


581 in true format 
Lelotelototsl folelsPetolel tet” 
plus (reverse bit states) 


PET P DDT PPP Te] aT o] one's complement fornat 


+] (add one) 


GODT TTT TTT ToLaTy) 781 i t's comtenen 


minus 


The highest possible number in two's complement form is +32,767. 
0 le 
1 


FH Ed 
plus 


The lowest possible number in two's complement form is -32,768. 
0 15 
|1}ofofo}o}ofofojo}ofojofofojofo | 


A minus 


Zoned Decimal Format 


In the zoned decimal format, each digit 0-9 is held in one byte. Bits 
4-7 of a byte hold the digit 0-9 in the standard binary format; this 
is called the digit portion of a byte. Bits 0-3 of a byte are always 
W163 this is called the zone portion of the byte. 


dififofefofo} = = 


Zone Digit 

uti ti foi [i Jo] = % 
Zone Digit 

PoODDE PPT] - ( 
Zone Digit. 
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Since each digit requires a byte, a three-digit field requires three 
bytes, a seven-digit field requires seven bytes, and so forth. The 
number 10 would occupy two bytes. 


Pr Lepfofofofiyifif ifs] efo polo 


Zone Digit ae ae Digit 


The digit portions equal |! and 0, or 10. 


All numeric fields must have a sign, and in the zoned decimal format 

the first four bits (0-3) of the rightmost byte are used to hold a sign. 
A hexadecimal C is a plus sign, and a hexadecimal D is a minus sign. 

The number +10 would appear as follows: 
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Packed Decimal Representation 


In the zoned decimal format, a byte is required to hold each digit, 0-9. 
The zone portion of each byte is unused (except for the sign in the right- 
most byte). These zoned decimal fields can be packed into a fewer number 
of bytes if these zones are removed; thus a packed or unzoned decimal 
format. In the packed format, the 4-bit sign is moved to the last four 
bits of the rightmost byte. 


The following illustration shows the number 18,634 in a zoned format 
and a packed (unzoned) format. Note the difference in placement of the 
sign. For easier interpretation, the actual bit patterns are not shown. 


Zoned 


Eee ee ee 


Zone Digit Zone Digit Zone Digit Zone Digit Sign Digit 


Packed 


pi ts tot stad 


Digit Digit Digit Digit Digit Sign 


lf a field with an odd number of digits is packed, no portion of the 
packed field is unused. If a field with an even number. of digits is 
packed, however, the first four bits of the packed field are unused, 
and are filled with zeros. 


In the last example, 18,634 was converted from a five-byte zoned field 

to a three-byte packed field. For the number 618,634, the zoned field 
requires six bytes and the packed field four bytes. The zoned and packed 
fields would appear as follows. The unused portion of the leftmost byte 
of the packed field is considered zero. 


Zoned 


Ea eae ae: 


Zone Digit Zone Digit Zone Digit Zone Digit Zone Digit Sign Digit 


Packed 


Zero Digit Digit Digit Digit Digit Digit Sign 

In packed decimal format, there are several 4-bit patterns for plus 
and minus. The following 4-bit patterns, identified in hexadecimal 
notation, indicate plus or minus. 


Pluss: “Py cAy (65 6, Oy 2y- 456. 75 ore 8 


Minus: By Dey oy Sa Or 4 
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Addressing 


The data involved in an instruction can be in one of three places: 

in the instruction itself, in a general register, or in main storage. 

If the data is in the instruction, there really is no addressing; if 

it is in a general register, the programmer simply provides the 

register number. But if the data is in main. storage, there are several 
techniques for defining the location of that data to the computer. 

The following material discusses the basic addressing techniques and 

how these techniques are combined. For ease of presentation, all numbers 
in the object formats in this section are decimal numbers. 


IMMEDIATE DATA 


Data held in the instruction is called immediate data, since it is 
immediately available to the computer; there is no addressing in- 
volved. 


Register Number 


Immediate Data 
Add Immediate - oad : 
a 7 8 11 12 13 
[ OP CODE | 


The immediate value 12 (decimal) will be added to 
the contents of general register 5. (Bit 12 is 
0, indicating direct addressing of register 5.) 


Note: Bits 8 and 12 have a special use for many instructions, this 
is described in the discussions of direct and indirect addressing in 
this section. 


INDEXING 


Indexing is an addressing technique in which a memory address is added to 
the contents of a general register (1-7) to form the address of data used 


in the instruction. A general register used for indexing is called an 
index register. 


Indexing is optional for most of the 4-, 6-, and 8-byte instructions. For 
instructions that allow indexing the first register indicated (Rj) in an 
instruction is associated with the first memory address (M}), and the 
second register (R2) is associated with the second memory address (Mo). 

The following example, shows how indexing applies to a 6-byte instruction. 


Instruction contents in this and subsequent examples are expressed in 
decimal. 
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No Index Register Specified for 1350 
Index Register, Added to 820 
Add Memory - Memory 


0 vy 7 8 9 11 12 13 15 


Memory Memory Memory 
Addition: 880 [ 27 ] + 1350 [143 ]———p1350 [170] 


Data Data 


OP CODE 


Register | 
Indexing: 820 + [60 | ————-» 880 (final address) 


Index Value 


Several instructions use indexing to form a value used in the instruc- 
tion rather than to form an address. These instructions add an 
immediate value to the contents of the index register; the result is 
treated as data, not an address. ; 
Result Register 
Index Register, Added to 11200 
Add Direct - Register 


Register 5 
Indexing: 11200 + [460 —]|———-» 11660 (data) . 
Index Value 
Register 6 Register 6 
Addition: 11660 + [ 340 |———®[__12000 _] 
Data Results 


LIRECT AUDRESSING 


A direct address is one (a memory address or a register number) that is 
either the final address of the data used in the instruction, or an address 
used for indexing. A direct address is not the address of a second address. 


Direct addressing is indicated by bits 8 and 12 for instructions in which 


this technique applies. If the bit is 0 (off), direct addressing 
is indicated. 


In this example, bits 8 and 12 are off. This indicates that the reg- 


isters identified in the instruction contain the data used in the 
operation. 
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Direct Addressing of Register 5 
Direct Addressing of Register 3 
Add Register - Register. 
0 v 7 8 9 11 12 13 15 


Register 3 Register 5 Register 5 
Addition: [500 | + [ 350 |———p[ 850 | 


Data Data Results 


Direct addressing applies to register numbers and memory addresses. 
For 2-byte instructions, bit 8 is associated with Rj (identified in 
bits 9-11) and bit 12 is associated with Ro (identified in bits 13- 
15). For 4-byte instructions, bit 8 is associated with M] (identified 
in bits 16-31) and bit 12 is associated with Rg. Ry in these in- 
structions is used as an index register, and direct or indirect ad- 
dressing does not apply to index registers. For 6-byte instructions, 
bit 8 is associated with M] and bit 12 is associated with M2 (iden- 
tified in bits 32-47). The 8-byte instructions all use direct addres- 
sing - it is a requirement. 


The following 4-byte instruction shows an example of indexing and 


direct addressing of M) and R2. Recat ying Regi ster 


Direct Addressing of Register | 


Index Register 

Direct Addressing of Memory Address 2000 
Add Memory - Register 

0 F 


OP CODE 


Register 1. 
Indexing: | A | + 2000—————— > 2004 (final address) 


Index Value 


Memory Register 4 Register 4 
Addition: 2004 + [ 80 | ———+»|_ 300 _ 
Data Data Results 
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INDIRECT ADDRESSING 


An indirect address (memory address or a register number) is the address 

of a second address. This second address may be the final address of 

the data used in the instruction, or it may be an address used for indexing. 
The second address must always be a memory address; it cannot be a 

register number. An indirect memory address must be an even-numbered 
address; the final address may be even or odd-numbered, depending on 

the instruction used. 


Indirect addressing is indicated by bits 8 and 12 for instructions in 
which this technique applies. If the bit is 1 (on), indirect address- 
ing is indicated. In the following example, bit 8 is on (1) indicating 
that the register identified in bits 9-11 contains a memory address, 
and at that memory address is the data used in the instruction. Bit 

12 is off (0) indicating that the register identified in bits 13-15 
contains data, not an address of data. The data flow in the example 

is memory to register. 


Direct Addressing of Register 5 
Indirect Addressing of Register 3 
Add Register - ee 


7 8 9 9 11 12 13'y 15 


oweooe os fo] + 


Register 3 
Indirect 500 
Addressing: Final Address 
Memory Register 5 Register 5 
Addition: 1500 [as es ge 
Data Data Results 


Indirect addressing applies to register numbers and memory addresses 

in the same way that direct addressing does. Bits 8 and 12 are as- 
sociated with Rj and R2 for 2-byte instructions, with M] and Ro for 
4-byte instructions, and with M] and M2 for 6-byte instructions. In- 
direct addressing is not allowed for 8-byte instructions. The 
following example of a 6-byte instruction shows how indirect addressing 
works in combination with indexing. 


Index Register, Added to 2400 
Indirect Addressing of Memory Address 2400 
Index Register, Added to 2100 
Direct Addressing of Memory Address 2100 
Add Memory - Memory. 
0 


2-20 


2999.00] 


FOR MEMOREX INTERNAL USE ONLY 


Register ] . To 
Indexing: 2100 + 100 ——» 2200 (final address) determine 
. Index Value operand | 
address 
Indirect addressing: 2400 
4 Memory 
2400 [3000 | 
| Intermediate To 
Address determine 
. operand 2 
Memory Register 3 address 
Indexing: jE + [{ 50 J|——p 3050 (final address) 
Intermediate Index Value 
Address 


Memor Memory Memor 
Addition: 2200 + 3050 [120 ]——p3050 
Results 


Data Data 


In the preceding example, to determine the operand 2 address, the 
indirect addressing was resolved, then the indexing was done. This 
technique is called post-indexing, because the indexing is done after 
the indirect addressing is resolved. Almost all instructions in which 
indirect addressing and indexing are allowed use the post-indexing 
technique. Very few instructions use a pre-indexing technique, in which 
the indexing is done before the indirect addressing is resolved. The 
following example shows how post-indexing and pre-indexing differ. 
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POST- INDEXING PRE- INDEXING 


= 


The address of the operand is deter- The address of the operand is deter- 


mined by these steps: mined by these steps: 
Q) Indirect addressing Q) Indirect addressing 
Memory Ry 


M) -— Intermediate M) = [ Index Value |-pI ntermediate 
Address Address 
ee Indexing (2) Indexing 


Ry Memory 
Intermediate =| Index Final Intermediate __ Final 
Address Value Madress Address Address 
(3) Final address G3) Final address 


Final address Final address [Data | 


Note: Bits 8 and 12 in the object instructions are used as indicator 
bits; they indicate something to the computer that the operation code 
alone cannot do. These bits are not always used to indicate direct or 
indirect addressing; sometimes they tell the computer more about the 
operands or the operation itself. When used in such a manner, these 
bits are called function indicators; they may be turned on by the 
assembler in some cases and by the programmer in other cases. Function 
bits are clearly defined for each instruction that uses them in the 
section Machine Instructions. 
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MACHINE INSTRUCTION FORMATS 


All programs used in the computer, whether system, utility, or appli- 
cation programs, have one thing in common: when they are executed they 
reside in main storage as a series of machine instructions. Machine 
instructions can be directly executed by the computer; they are the 
result of a translation of source instructions. The source instruc- 
tions are in a format that can be easily interpreted by a programmer; 
the object (machine) instructions are in a format that is easily inter- 
preted by the machine. The following material describes the machine 
instructions in their object format, as they would appear in main 
storage. 


There are four basic machine instruction formats. 
RR Register-to-Register 
RX Register-to-Indexed Storage 


XX Indexed Storage-to-Indexed Storage 
SS Storage-to-Storage 


The machine instructions are divided into these four categories on 
the basis of the instruction length (2, 4, 6, or 8 bytes of 8 bits each) 


and the type of operations they perform. The most common variations 
of each type of instruction are illustrated in the following diagrams. 


RR_ Instructions (2-8yte) 
lq byte rie byte _ >| R = general register 


OP CODE ie Ry gl Ro | Ry general register 
2 general register 
R 
[oo cone ae | | immediate data 


; i = indicator bit for direct or 
DECODE i, ee | indirect addressing of Ry and/ 


or Ro 


P°] 
HT] 


Data flow is 1—> 2 
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RX Instructions (4-Byte) 
l¢————- byte »l¢—— by te-—___» | R,; = general register for indexing 


of Mor | 
crcooe | TN 


Ra = general register 


M = memory address 
OP CODE ee | = immediate data 
indirect addressing of M or 
Ro 


OP CODE 


Data flow is usually 1—p2 


XX Instructions (6-Byte) 


R,= general register for indexing 


k¢——_ byte —_pi¢—_—_ byte —_» | of M, 
OP CODE R= general register for indexing 
of M, 


M)= memory address 


M,= memory address 


i = indicator bit, for direct or 
indirect addressing of My 
or Mo 


Data flow is | —>2 
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SS Instructions (8-Byte) 


R; = general register for indexing 


}¢——— byte — pl ——- byte — —> of My 
OP CODE i ee Ro Ro = general register for indexing 
of Mo 
M4 
M) = memory address 
M2 
L, be My = memory address 


Ly; = field length 
Lo = field length 


Data flow is |——» 2 


An operation code in the first byte of each instruction tells the 
computer what type of operation to perform. This code is most 
easily represented as a two-digit hexadecimal number, each digit 
representing four bits. For instance, an Add Register - Regtster 
Operation would have the following source and object representation. 
(The object format uses hexadecimal numbers in this example.) 


ADDR R3. R5 


PET 


4—byte ——_plq¢— byte ——p| 


The operation code tells the computer what to do with the data, while 
the rest of the instruction is concerned with identifying the location 
or address of the data to be used in the instruction. 
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MACHINE 


INTRODUCTION 
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INSTRUCTIONS 


This section describes the regular set of machine instructions. The 
restricted (Control and 1/0) instructions. are described in Section 
iV, Theory of Operations (not included in this version). 


The instructions are grouped by function in the following order: 


Ie 
va 


3. 


Arithmetic 
Bit-Oriented 
Boolean Logic 
Branching 
Compare 

Data Conversion 
Data Transfer 
No Operation 
Service Request 


Shift 
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Within each group, the individual instructions are arranged alpha- 
betically by name. Each instruction description includes the source 
format, the object format, a discussion of the operation involved, 
and an example. The following rules apply to the instruction de- 
scriptions. 


e Most instructions must address even bytes in memory; 
the rest can address even or odd bytes. The instructions 
which can address even or odd bytes are identified by 
a bullet following the instruction name (such as, Compare 
Packed Decimal e). 


e The address of a memory field refers to the leftmost 
byte of that field. 


e A word is defined as two bytes (8 bits in a byte); the 
bit positions in a word are numbered left to right (0-15). 


e@e The operand fields of the instructions may be fixed or 
variable in length. Fixed-length operand fields may be 
one byte, one word (2 bytes), or two words (4 bytes) in 
length. Variable-length fields may range from 0-255 bytes. 


@e The operand fields for some instructions are contained in 
two registers or two words; however, only one register or 
word is addressed by the instruction. If the address of 
the operand is R, the operand may be at R and R+1 (plus 
one register) or R and R-1 (minus one register). For 
example: if R=5, the operand field may be in 5 and 6 or 
4 and 5. 


@e lf the address of the operand is M, the operand may be 
at M and M+l (plus one word) or M and M-1 (minus one word). 
For example: if M=1324, the operand field is a four-byte 
field occupying locations 1324, 1325, 1326, and 1327 (for 
M and M+1) or 1322, 1323, 1324, and 1325 (for M and M~-1). 


@ The Overflow bit (bit 0) in the Condition register is 
set if the results of a binary add or subtract exceed the 
limits of a signed one-word or two-word result field. 
Specifically, overflow is indicated if results > 2n-1-] 
or results < -2"-| (where n=16 or 32 bits). 


e The Link bit (bit 3) in the Condition register is set 
if the results of a binary add or subtract exceed the limits 
of an unsigned one-word or two-word result field. Specif- 
ically, link is indicated if results > 2-1 for an add 
(where n=16 or 32 bits), or if operand 1 > operand 2 for 
a subtract. 
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The source and object formats of the operands are defined using the 
following symbols. 


OP Code The operation codes are presented in hexadecimal 
(00 through FF). 


R A general register number, 0-7. The register 
may be used as a sending or receiving field or 
as an index register. 


M A memory address, 0-65,535. 


| An immediate value; the value varies depending 
on the instruction. The value may represent an 
amount used in an arithmetic operation, a shift 
count, a skip count, or a bit number. 


L A field length, usually 0-255, but longer for 
some instructions. For certain instructions 
the length of an operand field may be defined 
in the instruction. The length specified in the 
instruction overrides any previous field length 
definition, but is only in effect for that in- 
struction. 


An R, M, |, or L in source operand | is identified as R;, My, 1), or Ly3 
in source operand 2 they are identified as Ro, Mo, Ig, or Lo. If there 
is only one operand, no number is used (R, M, |, or L). These symbols 
are numbered so that they can be referred to easily (distinguishing 
between Ry} and Ro in the same instruction) and to make clear the loca- 
‘tion of these fields in the object format. 


An at-sign (@) in a source operand indicates indirect addressing, an 
optional feature. For the instructions in which a register is a send- 
ing or receiving field, the at-sign indicates indirect addressing for 
R; or Ro. If a field in memory is the sending or receiving field, 

the at-sign indicates indirect addressing of Mjor Mo. 


Index registers and field lengths are optional; they are enclosed in 
parentheses in a source operand. 
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The two major operand fields are separated by a comma. 


The following examples show how the source and object formats are illus- 
trated. The at-sign and any designations in parentheses are almost always 
optional; if any of these designations are not optional, this fact wil] 


be noted. Data flow is usually operand 1 to operand 2, unless otherwise 
stated. 


EXAMPLE | 0123 45 67 8 91011 12 13 1415 


1 
ADDR @R, ,@R, OP CODE 5 


An optional 


at-sign which Data flow {ts 1 to 2. 
turns on bit 
12 


An optional 
at-sign which 
turns on 

bit 8. 


The variations of this instruction are as follows: data flow may be reg- 


ister to register, register to memory, memory to register, or memory to 
memory, depending on the use of indirect addressing. 


( Ry l Ro There are2 x 2 = 4 possible variations 
oer aR, aR, of this instruction. 


EXAMPLE 2 012 3 45 6 7 8 91011 12 13 14 15 


cca Sf fa] Re 
0 
ADDM @Mj(Ry) ,@M2 (Ro) 


My 


M2 


An optional index register 
added to My 


An optional at-sign which turns on bit 12, 
specifying indirect addressing of Mo 


An optional index register added to My 


An optional at-sign which turns on bit 8, specifying indirect 
addressing of My 
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The data flow of this instruction is always memory to memory. Any varia- 
tion of operand 1 can be used with any variation of operand 2. 


.) Mo 
@M, | @M> There are4 x 4 = 16 
ADDM ; ree 
My (R,) Mg (Ro) possible variations of 
QM, (R, ) @M> (Ro) this instruction. 
Timing formulas for all instructions are included as a part of Appendix 
C to this document. 
3°5 
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ARITHMETIC INSTRUCTIONS 


Mnemonic Code Name 
ADDD Add Direct 
ADDI Add Immediate 
ADDM Add Memory - Memory 
ADD Add Memory - Register 
ADDK Add Packed Decimal e 
ADDR Add Register - Register 
ADDT Add Two-Word 
DIVD Divide Direct 
DIVI Divide Immediate 
DIVM Divide Memory - Memory 
DIV Divide Memory - Register 
DIVK Divide Packed Decimal 
DIVR Divide Register - Register 
MPYD Multiply Direct 
MPY I Multiply Immediate 
MPYM Multiply Memory ~- Memory 
MPY Multiply Memory ~- Register 
MPYK Multiply Packed Decimal 
MPYR Multiply Register - Register 
SUBD Subtract Direct 
SUBI Subtract Immediate 
SUBM Subtract Memory ~ Memory 
SUB Subtract Memory - Register 
SUBK Subtract Packed Decimal e 
SUBR Subtract Register - Register 
SUBT Subtract Two-Word 
ZADK Zero and Add 


3-6 2999.00] 


FOR MEMOREX INTERNAL USE ONLY 
Add Direet 


ADDD 1(Ry), @R, 


FUNCTION: Performs a binary addition of a one-word immediate value* 
and a one-word field in a general register or in memory. 


OPERAND 1: A 16-bit immediate signed value in bits 16-31 of the in- 
struction; the value may range from -32,768 to +32,767. 


*I Indexing may be specified for operand 1. In this case, operand | is 
derived by adding the | value and the general register contents specified 
by Ry}; no check for overflow or link is made during the indexing. 


OPERAND 2: A one-word field in the general register specified by Ry or 
in memory if indirect addressing is used, bit 12=]. 


RESULTS: The resulting sum resides at the operand 2 location. The Con- 


dition register is affected as follows: 


e Bit 0 (overflow) is set if the result is greater than 
+32,767 or less than -32,768. 

e Bits 1-2 and 4-7 are cleared. 

e Bit 3 (link) is set if the result is greater than 65,535. 


EXAMPLE: ADDD 15000(2),3 


The immediate value of 15,000 is modified by the contents of register 2 
and added to the value in register 3. The sum remains in register 3. 


If @ (indirect addressing) is specified, register 3 contains a memory 
address. 
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Add Immedtate 


0 78 11 12 13 15 
poor 1,0 7 BT | 


FUNCTION: Performs a binary addition of a 4-bit immediate value and a 
one-word field in a general register or in memory. 


OPERAND 1: A 4-bit unsigned value located in bits 8-11 of the instruction; 
the value may range from 0-15. The | value is added to operand 2 in 
bit positions 12-15 with bits O-11 zeros. 


OPERAND 2: A one-word field in the general register specified by R or 
in memory if indirect addressing is used, bit 12=]. 


RESULTS: The resulting sum resides at the operand 2 location. The Con- 
dition register is affected as follows: 


@e Bit 0 (overflow) is set if the result is greater than +32,767 
or less than -32,768. 

e Bits 1-2 and 4-7 are cleared. 

e Bit 3 (link) is set if the result is greater than 65,535. 


b 


EXAMPLE: ADDI 10,04 


The immediate value of 10 is added to the operand at the memory address 
specified in register 4, at which address the sum is also placed. 


If @ (indirect addressing) is not specified, the register contains an 
operand and subsequent sum, rather than an operand address. - 
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Add Memory — Memory 


0 7 8 Q 11.12 13 


zs Bs Bl 
ADDM @M) (Ry) ,@M, (R,) i 2 


M2 


FUNCTION: Performs a binary addition of two one-word fields in memory. 


OPERAND 1: A one-word field in memory. Addressing options to the base 
address M, include indexing (Ry ), indirect addressing (bit 8=1), ora 
combination of both. 


OPERAND 2: Same as operand |] except use Mj, Ro, and bit 12=1. 


RESULTS: The resulting sum resides at the operand 2 location. The 
Condition register is affected as follows: 


e Bit 0 (overflow) is set if the result is greater than 
+32,767 or less than -32,768. 

@ Bits 1-2 and 4-7 are cleared. 

@ Bit 3 (link) is set if the result is greater than 65,335. 


EXAMPLE: ADDM @HERE(3) ,@TAG(2) 


@HERE(3) identifies a 16-bit operand which is added to another operand 
identified by @TAG(2). The subsequent sum is located at the address 
specified at @TAG(2). 
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Add Memory — Regtster 


0 7 8 9 11 12 13 15 


A R 
no any [ils [Ls 


FUNCTION: Performs a binary addition of a one-word field in memory and 
a one-word field in a general register or in memory. 


QPERAND 1: A one-word field in memory. Addressing options to the base 
address M include indexing (Rj), indirect addressing (bit 8=1), or a 
combination of both. 


QPERAND 2: A one-word field in the general register specified by Ro 
or in memory if indirect addressing is used, bit 12=1. 


RESULTS: The resulting sum resides at the operand 2 location. The Con- 
dition register is affected as follows: 


e Bit O (overflow) is set if the result is greater than +32, 767 
or less than -32,768. 


e Bits 1-2 and 4-7 are cleared. 
e Bit 3 (link) is set if the result is greater than 65,535. 


EXAMPLE: ADD TAG(5),7 


A 16-bit operand identified by TAG(5) is added to the contents of 
register 7. 


Although not specified in the example, @ (indirect addressing) can be 
applied to both operators. 
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Add Packed Decimal e 


0 7 11 12 13 15 


ADDK = My (Ly »Ry) Mo (Lo Ro) 


FUNCTION: Performs a signed decimal addition, proceeding from right to 
left, of the two packed decimal fields in memory. The field lengths Ly 
and Ly may vary from 0-255 bytes. 


QOPERAND 1: A packed decimal field in memory. The field length, 0-255 
bytes, is specified in the L, field of the instruction. The operand address 
indicated by My; may be indexed (Ry); but indirect addressing is not 

allowed. The effective address points to the most significant bytes of 

the decimal field. 


OPERAND 2: A packed decimal field in memory. The field length, 0-255 
bytes, is specified by the Ly value in the instruction. The operand 
address indicated by Mo may be indexed (Ry); but indirect addressing is 
not allowed. The effective operand address points to the most significant 
bytes of the decimal field. 


RESULTS: The resulting decimal sum resides at the operand 2 location. 
The following conditions can occur, depending on the values of Lj and 
Lo. | 


e if lL) is greater than Ly and the difference between L 
and Ly contains significant data, bit 0 of the Condition 
register is set. 

e If L} = 0 and Lo = 0, bit 3 of the Condition register is set. 

If L} = 0, an add of zero is assumed. 

e if Lg is greater than L}, zeros are used to make up the difference 
in field lengths. 


The Condition register is also affected as follows: 


e Bit 0 is set if significant data is lost; bits 1-7 are cleared. 

e Bits | and 5 are set if results are plus; bits 0, 2-4, and 
6-7 are cleared. 

e Bits 2 and 6 are set if results are minus; bits 0-1, 3-5, and 
7 are cleared. 

e Bits 3 and 7 are set if results are zero; bits 0-2, and 4-6 
are cleared. 


FOR MEMOREX INTERNAL USE ONLY 
EXAMPLE: ADDK  FIELD2(10,5),FIELDI(12,6) 


A 10-byte packed field identified by FIELD2(10,5) is added to a 12-byte 
packed field identified by FIELDI(12,6). Had the field lengths been 
reversed (that is, trying to add the larger field to the smaller) and 
the overlap contains significant (non-zero) bytes, bit 0 of the Con- 
dition register is set to indicate lost data (an incorrect add). 
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Add Register — Register 


0 7 8 9 11.12 13 15 


. 22 
ADDR OR, 8R, | Be 


FUNCTION: Performs a binary addition of two one-word fields; either field 
may be in a general register or in memory. 


QOPERAND 1: A one-word field in the general register specified by Rj or in 
memory if indirect addressing is used, bit 8=1]. 


QPERAND 2: A one-word field in the general register specified by Rg or in 
memory if indirect addressing is used, bit 12=1. 


RESULTS: The resulting sum resides at the operand 2 location. The 
Condition register is affected as follows: 


e Bit 0 (overflow) is set if the result is greater than 
+32,767 or less than -32,768., 

e Bits 1-2 and 4-7 are cleared. 

e Bit 3 (link) is set if the result is more than 65,535. 


EXAMPLE: ADDR @4,@1 


In this example, both source operands specify indirect addressing; there- 
fore, register 4 and register 1 contain memory addresses of operands. The 
operation adds the operand found through register 4 to the operand found 
through register 1 (sum remains at the latter location). 
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Add Two-Word 
sara ccs 


FUNCTION: Performs a binary addition of a two-word field in MEMORY. and 
a two-word field in two general registers or in memory. 


ADDT @M(Rj),@R> 


OPERAND 1: A two-word field in memory at the effective address. 
Addressing options to the base address M include indexing (Rj), in- 
direct addressing (bit 8=1), or a combination of both. 


OPERAND 2: A two-word field located in two general registers (the most 
significant bits in the register specified by Rg and the least significant 
bits in the register R7+1) or in memory at the address if indirect 
addressing is used, bit 12=1]. (Note: If register 7 is specified by 

Ro, the most significant bits are in register 7 and the least significant 
bits are in register 0.) 


The effective address points to the most significant word of the operand. 


RESULTS: The resulting sum resides at the operand 2 location. The 
Condition register is affected as follows: 


@ Bit 0 (overflow) is set if the result is greater than +231] 
or less than -23] 


@ Bits 1-2 and 4-7 are cleared. 
@ Bit 3 (link) is set if the result is greater than +222-1, 


EXAMPLE: ADDT TAG(1),5 


TAG(1) identifies a two-word field which is added to the contents of 
registers 5 and 6. The two word sum remains in registers 5 and 6. 


Although not used in this example, @ can precede each operator to specify 
indirect addressing. 
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Divide Direct 


DIVD 1(R)),@R> 


FUNCTION: Performs a binary division; the divisor is a one-word immediate 
value* » and the dividend is a two-word Field in two general registers or 
in memory. 


OPERAND 1: The divisor; a 16-bit immediate signed value in bits 16-3] 
of the instruction; the value may range from -32,768 to +32, 767. 


*Indexing may be specified for operand 1. In this case, operand 1 is 
derived by adding the | value and the general register contents specified 
by Ry; no check for overflow or link is made during the indexing. 


OPERAND 2: The dividend; a 32-bit signed value contained in a two- 
word field. 


If direct addressing is used (bit 12=0), the least significant bits are 
in the register specified by Rg and the most significant bits are in the 
register Ro-1. (Note: If register 0 is specified by Rg, the least 
significant bits of the dividend are in pegs cer O and the most 
significant bits are in register 7.).. 


If indirect addressing is used (bit 12=1), the least significant bits 
are in memory at the effective address and the most significant bits 
at the effective address -2. 


RESULTS: The quotient, a l6-bit signed value, resides at the Ro register 
or the effective address of the operand 2 location. The remainder, a 
16-bit signed value, resides at the Ro-1 register or effective address 

~2 of the operand 2 location; the remainder always has the same sign as 
the dividend. 


The Condition register is affected as follows: 
@ Bit 0 (overflow) is set if the resulting quotient is greater 
than +32,767 or less than -32,768. 


e Bit 0 (overflow) is set if the divisor is 0; the operands are 
unchanged. 
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EXAMPLE: DIVD -32255(4),@3 
The instruction specifies a binary divide in which the divisor is formed 
by adding -32,255 to the contents of register 4, and the dividend is 
found at the address specified in register 3. 
As shown in the following illustration, the address specified in register 


3 points to the third byte of the 32-bit dividend. This is the 4-byte 
field in memory that holds the dividend. 


i Dividend 


Sign bit 


Address in register 3 
points here 


After the division, the quotient (including sign bit) is placed in the 
third and fourth bytes and the remainder (also with sign bit) is placed 
in bytes one and two. Thus, for subsequent operations, the quotient 
can be found at the address as specified in register 3. This is the 
same field after the divide operation. 


| rensinser | | avotione 
v 


Sign bit Sign bit 


Address in register 3 
points here 
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Divide Immediate 


0 7 8 11 12 13 15 


DIVE tek | ae ee 


FUNCTION: Performs a binary divide; the divisor is a 4-bit immediate 
value, and the dividend is a two-word field in two general registers or 
in memory. 


OPERAND 1: The divisor is a 4-bit unsigned value in bits 8-11 of the 
instruction; the value is always positive and may range from 0-15. 


OPERAND 2: The dividend; a 32-bit signed value contained in a two-word 
field. 


If direct addressing is used (bit 12=0), the least significant bits are 
in the register specified by Rj and the most significant bits are in the 
register R. (Note: If register 0 is specified by R, the least 
significant bits of the dividend are in register 0 and the most signif- 
icant bits are in register 7.) 


If indirect addressing is used (bit 12=1), the least significant bits 
are in memory at the effective address and the most significant bits at 
the effective address -2. . 


RESULTS: The quotient, a 16-bit signed value, resides at the R register 
or the effective address of the operand 2 location. The remainder, a 
16-bit signed value, resides at the R-1 register or effective address 

-2 of the operand 2 location; the remainder always has the same sign 

as the dividend. 


The Condition register is affected as follows: 


e Bit 0 (overflow) is set if the resulting quotient is greater 
than +32,767 or less than -32,768. 

e Bit 0 (overflow) is set if the divisor is 0; the operands 
are unchanged. 


EXAMPLE: DIVI 14, @1 


Divides a 32-bit field (31 bits plus sign) by 14. The divisor is an 
absolute value in the instruction, and the dividend is located in memory 
according to the method described under DIVD. The quotient is stored at 
the address specified in register I. 


3-17 2999.00] 
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Divide Memory — Memory 


9 11 12 13 15 
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FUNCTION: Performs a binary division; the divisor is a one-word field in 
_ memory, and the dividend is a two-word field in memory. 


OPERAND 1: The divisor; a l6-bit signed value in a one-word field in 
memory. Addressing options to the base address M] include indexing (Rj), 
indirect addressing (bit 8=1), or a combination of both. 


OPERAND 2: The dividend; a 32-bit signed value in memory at the effective 
address and the effective address -]. Addressing options to the base 
address My include indexing (R2), indirect addressing (bit 12=1), or 

a combination of both. The effective operand 2 address points to the 
least significant bits of the dividend. 


RESULTS: The quotient, a l6-bit signed value, resides at the effective 
address of the operand 2 location. The remainder, 16-bit signed value, 
resides at the effective address -2 of the operand 2 location. The 
remainder always has the sign of the dividend. 


The Condition register is affected as follows: 


e Bit 0 (overflow) is set if the resulting quotient is 
greater than +32,767 or less than -32,768. 

e Bit 0 (overflow) is set if the divisor is zero; the operands 
are unchanged. 


EXAMPLE: DIVM @HERE(6),@TAG (4) 


TAG(4) and HERE(6) are locations each containing an address of an operand. 
The operand identified by @TAG(4) is divided by the operand identified by 
@HERE(6). The dividend is a four-byte field; the address of the dividend, 
@TAG(4), points to the third byte of the four-byte field. After the 
division, this address points to the quotient; this address minus two 
bytes points to the remainder. 
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FOR MEMOREX INTERNAL USE ONLY 


Divtde Memory — Register 


DIV @M(Rq),@R. 


FUNCTION: Performs a binary division; the divisor is a one-word field 
in memory, and the dividend is a two-word field in two general registers 
or in memory. 


QOPERAND 1: The divisor; a 16-bit signed value in a one-word field in 
memory. Addressing options to the base address M include indexing 
(Rj), indirect addressing (bit 8=1), or a combination of both. 


OPERAND 2: The dividend; a 32-bit signed value contained in a two-word 
field. 


If direct addressing is used (bit 12=0), the least significant bits are 
in the register specified by Rg and the most significant bits are in the 
register Ro-1. (Note: If register 0 is specified by Ro, the least 
significant bits of the dividend are in register 0 and the most signifi- 
cant bits are in register 7.) 


If indirect addressing is used (bit 12=1), the least significant bits 
are in memory at the effective address and the most significant bits are 
at the effective address - 2. 


RESULTS: The quotient, a l6-bit signed value, resides at the R72 register 
or the effective address of the operand 2 location. The remainder, a 
16-bit signed value, resides at the Ro-1 register or effective address 

~ 2 of the operand 2 location; the remainder always has the same sign 

as the dividend. 


The Condition register is affected as follows: 
e Bit 0 (overflow) is set if the resulting quotient is 
greater than +32,767 or less than -32,768. 


@ Bit 0 (overflow) is set If the divisor is 0; the operands are 
unchanged. 
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FOR MEMOREX INTERNAL USE ONLY 


0 if divisor = 0 


Ey 
1 if divisor # 0 


Ey 
EXAMPLE: DIV TAG (4) ,@Z. 


Register 2 contains the address (see DIVD) of the dividend (32-bit 
operand), and TAG(4) identifies the divisor (16-bit operand). The 
quotient is at the address in register 2, and the remainder is at 
that address minus two bytes. . 


Although not shown in the example, @ (indirect addressing) can be 
specified for the divisor also. 
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Divide Packed Deetmat 
0 7 8 9 111213 15 


DIVK —- My (Ly 4Ry) »Mp (Lo »Ro) 


FUNCTION: Operand two, the dividend, is divided by operand one, the 
divisor, and replaced by the quotient and remainder. 


OPERANDS: The quotient field is placed leftmost [in the operand two, 
dividend field. The remainder field is placed rightmost in the same 
field and has a size equal to the length code, L,, of the divisor. The 
quotient and remainder occupy the entire dividend field, thus the address 
of the dividend, operand two, is the address of the quotient. The size 
of the quotient field is Lo-Ly. 


The length code, L,, of the divisor must not exceed 127 (253 digits and 
sign) or be greater than or equal to the length code, Lo, of the dividend. 
Otherwise, overflow occurs and the operation is not performed. Also, a 
length code of zero for the divisor or zero divisor field contents causes 
overflow and operation suppression. The range of L} is 1-127, the range 
of Ly is 2-255. The divisor, dividend, quotient and remainder are al} 
signed packed decimal fields right-aligned. The sign of the quotient is 
determined by the rules of algebra. The sign of the remainder has the 
same value as the dividend sign. Sign validity checking is not performed. 
The following rules apply: 


plus: hex 0,2,4,6,7,8,A,C,E,F 
minus: hex 1,3,5,9,B,D 


The preferred sign; plus, X'C', and minus, X'D', are generated. A 
minus zero quotient or remainder is forced to plus. 


The operand fields remain unchanged if overflow occurs. 


RESULTS: The operand fields may not overlap. Invalid digits cause 
undefined results. The following condition register settings can occur: 


Bits 0-7 Condition 
1000 0000 Overflow, Ly >127; Ly >L,, Ly=0; or; 
divisor field contents of zero 
0100 0100 | | The quotient Is greater than zero 
0010 0010 | | | The quotient is less than zero 
00017 0001 The quotient is equal to zero 
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Divide Register — Register 
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FUNCTION: Performs a binary division; the divisor is a one-word field in 
a register or in memory, and the dividend is a two-word field in two 
adjacent registers or in memory. 


OPERAND 1: The divisor; a 16-bit signed value in the general register 
specified by R;} or in memory if indirect addressing is used, bit 8=1, 


OPERAND 2: The dividend; a 32-bit signed value contained in a two-word 
field. 


If direct addressing is used (bit 12=0), the least significant bits are 

in the register specified by Ro and the most significant bits are in the 
register Ro-1l. (Note: If register 0 is specified by R2, the least 
significant bits of the dividend are in register 0 and the most significant 
bits are in register 7.) 


If indirect addressing is used (bit 12=1), the least significant bits 
are in memory at the effective address and the most significant bits 
are in the effective address - 2. 


RESULTS: The quotient, a 16-bit signed value, resides at the Ro 

register or the effective address of the operand | location. The re- 
mainder, a 16-bit signed value, resides at the Ro-1 register or effective 
address - | of the operand 2 location; the remainder always has the same 
sign as the dividend. 


The Condition register is affected as follows: 


e Bit 0 (overflow) is set if the resulting quotient is greater 
than +32,767 or less than -32,768. 


@ Bit 0 (overflow) is set if the divisor is 0; the operands are 
unchanged. 


EXAMPLE: DIVR  @1,@3 


A binary divide is performed on a 32-bit (31 plus sign bit) dividend 
residing at the address specified in register 3. The 16-bit divisor 
resides at a location specified in register 1; the quotient is stored at 


the address in register 3; the remainder is stored at that address minus 
two bytes. 
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Multiply Dtreect 


MPYD 1(Ry),@R., 


FUNCTION: Performs a binary multiplication of a one-word immediate 
value* and a one-word field in a general register or in memory. 


OPERAND 1: The multiplier; a l6-bit immediate signed value in bits 
16-31 of the instruction; the value may range from -32,768 to +32, 767. 


*Indexing may be specified for operand 1. In this case, operand | is 
derived by adding the | value and the general register contents 
specified by Ry}; no check for overflow or link is made during the 
indexing. 


OPERAND 2: The multiplicand; a one-word field in the general register 
specified by Ra or in memory if indirect addressing is used, bit 12=1. 


RESULTS: The product, a 32-bit signed value, resides at the operand 2 
location. I!f-operand 2 is in a register, the least significant bits 
of the product are in the register specified by Ry and the most 
significant bits are in register Ro-l. (Note: If register 0 is 
specified by R9, the least significant bits are in register 0 and the 
most significant bits are in register 7.) If operand 2 is in memory, 
the least significant bits of the product are at the effective address 
and the most significant bits are at the effective address - 2. 


EXAMPLE: MPYD 16101(3),@1 


A 16-bit (includes sign) multiplicand at the address in register 1 jis 
multiplied by the sum of 16,101 and the contents of register 3. The 
32-bit (includes sign bit) product is stored at the address in register 
} minus two bytes. 
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Multiply Immediate 


0 7 8 11. 12 13 15 


FUNCTION: Performs a binary multiplication of a 4-bit immediate value and 
a one-word field in a general register or in memory. 


OPERAND 1: The multiplier; a 4-bit unsigned field located in bits 8-1] 
of the instruction; the value is always positive and may range from 0-15. 


OPERAND 2: The multiplicand; a one-word field in the general register 
specified by R or in memory if indirect addressing is used, bit 12=]. 


RESULTS: The product, a 32-bit signed value, resides at the operand 2 
location. If operand 2 is in a register, the least significant bits 

of the product are in the register specified by R and the most significant 
bits are in register R-1]. (Note: If register 0 is specified by R, 

the least significant bits are in register 0 and the most significant 

bits are in register 7.) If operand 2 is in memory, the least significant 
bits of the product are at the effective address and the most significant 
bits are at the effective address - 2. 


EXAMPLE: MPYI 15,@6 


The multiplicand located at the address specified in register 6 is 


multiplied by 15. The subsequent product is stored at the address in 
register 6 minus two bytes. 


FOR MEMOREX INTERNAL USE ONLY 
Multiply Memory — Memory 
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FUNCTION: Performs a binary multiplication of two one-word fields in 
memory. 


QPERAND |: The multiplier; a one-word field in memory. Addressing 
options to the base address M; include indexing (R,), indirect ad- 
dressing (bit 8=1), or a combination of both. 


OPERAND 2: The multiplicand; a one-word field in memory. Addressing 
Options to the base address My include indexing (Ro), indirect addressing 
(bit 12=1), or a combination of both. 


RESULTS: The product; a 32-bit signed value. The least significant 
bits reside at the operand 2 effective address, and the most significant 
bits reside at the operand 2 effective address - 2. 


EXAMPLE: MPYM @FRRD(5),@TTM(2) 
The location of the multiplicand is defined by @TTM(2), and the location 


of the multiplier by @FRRD(5). The 32-bit product is stored at the 
operand 2 address minus two bytes. 
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FUNCTION: Performs a binary multiplication of a one-word field in memory 
and a one-word field in a general register or in memory. 


OPERAND 1: The multiplier; a one-word field in memory. Addressing 
options to the base address M include indexing (R,), indirect addressing 
(bit 8=1), or a combination of both. 


OPERAND 2: The multiplicand; a one-word field in the general register 
specified by R2 or in memory if indirect addressing is used, bit 12=1. 


RESULTS: The product, a 32-bit signed value, resides at the operand 2 
location. If operand 2 is in a register, the least significant bits of 
the product are in the register specified by R2 and the most significant 
bits are in register Ra-1. (Note: If register 0 is specified by Ro, 

the least significant bits are in register 0 and the most significant 
bits are in register 7.) !f operand 2 is in memory, the least significant 
bits of the product are at the effective address and the most significant 
bits are at the effective address - 2. 


EXAMPLE: MPY @FRRD(2}@1 


The multiplicand located at the address specified in register 1 is 
multiplied by a value at a location determined by @FRRD (2). 
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Multtply Packed Deetmal 


MPYK = My (Ly ,Rz) »Mp (Lo yRo) 


FUNCTION: The product of operand 1 (the multiplier) and operand 2 (the 
multiplicand) replaces operand 2. The multiplier size is limited to 253 
digits and sign and also must be less than the multiplicand size. The 
length code, L,}, of the multiplier, if larger than 127, or greater than 
or equal to the length code, Ly, of the multiplicand is recognized as 

an overflow and no product is formed. 


OPERANDS: Since the number of digits in the product is the sum of the 
digits in the operands, the multiplicand must have high-order zero bytes 
for at least a field size that equals the multiplier field size; other- 
wise, an overflow condition occurs. This definition of the multiplicand 
field insures that no product overflow can occur during the operation. 
At least one high-order digit of the product field is zero. 


A field size specification of zero, length code L,;, for the multiplier 
causes an effective multiply by zero if the multiplicand length code, 
Ly, is non-zero. If either operand (or both) contains all zeros, the 
product field is set to zeros and a sign of plus (X'C') is forced. The 
range of L; is 0-127, the range of Ly is 1-255. 


The sign of the product is determined by the rules of algebra. Sign 
validity is not checked, therefore, the following interpretations are 
made: 


plus hex  0,2,4,6,7,8,A,C,E,F 
minus hex 1,3,5,9,8,D 


The fields may not overlap. Digit validity is not checked, undefined 
results will occur if non-decimal digits occur. If an overflow condition 
occurs, the operands remain unchanged. The preferred signs of X'C' for 
plus and X'D' for negative are generated for the product. A negative 
zero result is forced to plus. 


RESULTS: The following condition register settings can occur: 


Bits 0-7 Condition 

1000 0000 Overflow: Ly, >127; Ly 2L5; or; 
less than L, bytes of nien-order 
zeros in the multiplicand 


0100 0100 Product is greater than zero. 
0010 0010 Product is less than zero. 
0001 0001 Product is equal to zero. 
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Multiply Register — Register 
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FUNCTION: Performs a binary multiplication of two one-word fields; either 
field may be in a register or in memory. 


OPERAND |: The multiplier; a one-word field in the general register 
specified by R; or in memory if indirect addressing is used, bit 8=1. 


OPERAND 2: The multiplicand; a one-word field in the general register 
specified by Ry or in memory if indirect addressing is used, bit 12=1]. 


RESULTS: The product, a 32-bit signed value, resides at the operand 2 
location. If operand 2 is in a register, the least significant bits of 
the product are in the register specified by Rp and the most significant 
bits are in register Ro-1. (Note: If register 0 is specified by Ro, 

the least significant bits are in register O and the most significant 

bits are in register 7.) If operand 2 is in memory, the least significant 
bits of the product are at the effective address and the most significant 
bits are at the effective address -2. 


EXAMPLE: MPYR @6,@7 


The multiplicand at the memory location specified in register 7 is 
multiplied by the multiplier residing at the memory location specified in 
register 6. The multiplicand and multiplier are 16-bit operands while 
the subsequent product is 32 bits. The product is stored at the 

address in register 7 minus two bytes. 
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Subtract Direct 
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FUNCTION: Performs a binary subtraction of a one-word immediate value* 
from a one-word field in a general register or in memory. 


QPERAND 1: A 16-bit immediate signed value in bits 16-31 of the 
instruction; the value may range from -32,768 to +32,767. Operand | is 
subtracted from operand 2. 


*Indexing may be specified for operand 1. In this case, operand | is 
derived by adding the | value and the general register contents specified 
by Ry; no check for overflow or link is made during the indexing. 


QPERAND 2: A one-word field in the general register specified by Rg or 
in memory if indirect addressing is used, bit 12=1]. 


RESULTS: The resulting difference resides at the operand 2 location. 
The Condition register is affected as follows: 


e Bit 0 (overflow) is set if the result is less than -32,768 or greg 
than +32,767. 

e Bits 1-2 and 4-7 are cleared. 

Bit 3 (link) is set if the result is greater than 65,535. 

e Subtracting 8000) ¢ from 00001 ¢ results in 8000.. and bit 
0 is set. 16 


EXAMPLE: SUBD TAG(5),@0 


A two's complement binary subtraction is performed. The subtrahend 
address is contained at the location specified by @TAG(5). 


The minuend, from which the subtrahend is subtracted, resides at a 
memory location identified by the address specified in register 0. 
(Without indirect addressing, the minuend is contained in the named - 
register.) The subsequent difference is stored at the location of 
the minuend. 
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Subtract Immediate 
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FUNCTION: Performs a binary subtraction of a 4-bit field from a one-word 
field in a general register or in memory. 


OPERAND 1: A 4-bit unsigned value located in bits 8-11 of the instruction; 
the value may range from 0-15. The | value is subtracted from bits 12-15 
of operand 2; bits 0-11 of operand 1 are zeroed out. 


OPERAND 2: A one-word field in the general register specified by R 
or in memory if indirect addressing is used, bit 12=1]. 


RESULTS: The resulting difference resides at the operand 2 location. The 
Condition register is affected as follows: 


e Bit 0 (overflow) is set if the result is less than -32,768. 


or greater than +32, 767. 
e Bits 1-2 and 4-7 are cleared. 
e Bit 3 (link) is set if the result is greater than 65,535. 


EXAMPLE: SUBI 14,@4 


The immediate value, 14, is subtracted from the 16-bit minuend residing 
at the memory location specified in register 4, which also is the 
location of the difference. 
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Subtract Memory — Memory 
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FUNCTION: Performs a binary subtraction of two one-word fields in memory. 


OPERAND 1: A one-word field in memory. Addressing options to the base 
address M; include indexing (R}), indirect addressing (bit 8=1), or a 
combination of both. This operand is subtracted from operand 2. 


OPERAND 2: Same as operand | except use My, Ry, and bit 12=1. 


RESULTS: The resulting difference resides at the operand 2 location. 
The Condition register is affected as follows: 


e Bit 0 (overflow) is set if the result is greater than 
+32,767 or less than -32,768 

e Bits 1-2 and 4-7 are cleared. . 

Bit 3 (link) is set if the result is greater than 65,535. 

@e Subtracting 8000)¢ from 0000,¢ results in 8000)¢ and bit 
O is set. 


EXAMPLE: SUBM  @BITL(6),@JLE(5) 


@BITL(6) defines the memory location of the subtrahend which is sub- 
tracted from the minuend pointed to by @JLE(5). Both operands and the 
difference are |l6-bit fields; the difference is at the location of the 
minuend. 
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Subtract Memory — Register 
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FUNCTION: Performs a binary subtraction of a one-word field in memory and 
a one-word field in a general register or in memory. 


OPERAND 1: A one-word field in memory. Addressing options to the base 
address M include indexing (Rj), indirect addressing (bit 8=1), or a 
combination of both. This operand is subyracted from operand 2. 


OPERAND 2: A one-word field in the general register specified by Ro or 
in memory if indirect addressing is used, bit 12=1. 


RESULTS: The resulting difference resides at the operand 2 location. The 
Condition register is affected as follows: 


e Bit 0 (overflow) is set if the result is greater than +32, 767 
or less than -32,768. 

e Bits 1-2 and 4-7 are cleared. 

e Bit 3 (link) is set if the result is greater than 65,535. 

e Subtracting 80001 ¢ from 0000;¢ results in 8000)¢ and bit 0 
is set. 


EXAMPLE: SUB @TAG(5),@7 


The location of the subtrahend is defined by @TAG(5), and that of the 
minuend by @7. Register 7 contains a minuend address which is also the 
address of the difference. @TAG(5) is the location in memory of the 
subtrahend. 
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FUNCTION: Performs a signed decimal subtraction of the two packed decimal 
fields in memory. The field lengths L, and L5 may vary from 0-255 bytes. 


OPERAND 1: A packed decimal field in memory which is subtracted from 
operand 2. The field length, 0-255 bytes, is specified by the L] value 
in the instruction. The operand address indicated by M,; may be indexed 
(Ry), but indirect addressing is not allowed. The effective operand 
address points to the most significant bytes of the decimal field. 


OPERAND 2: A packed decimal field in memory. The field length, 0-255 
bytes, is specified by the Lg value in the instruction. The operand 


address indicated by Mo may be indexed (Ro) » but indirect addressing is 
not allowed. The effective operand address points to the most significant 


bytes of the decimal field. 


RESULTS: The resulting decimal difference resides at the operand 2 
location. The following conditions can occur, depending on the values 
of Ly} and Lo. 


e If Lj is greater than L2 and the difference between L) and 
Lo contains significant data, bit 0 of the Condition register 


is set. 
@e if Lj} = 0 and Lo = 0, bit 3 of the Condition register is set. 
e If L} = 0, a subtract of zero is assumed. 


e if Log is greater than L}, zeros are used to make up the 
difference in field lengths. 


The Condition register is also affected as follows: 


e Bit 0 is set if significant data is lost; bits 1-7 are cleared. 
e Bits | and 5 are set if results are plus; bits 0, 2-4, and 
6-7 are cleared. 
e Bits 2 and 6 are set if results are minus; bits O-1, 3-5, and 
7 are cleared. 
e Bits 3 and 7 are set if results are zero; bits 0-2, and 4-6 
are cleared. 
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EXAMPLE: SUBK  FIELDI(105,2),FIELD2(201,4) 


In this example, a 105-byte field is subtracted from a 201-byte field. 
The location of the subtrahend is FIELDI(105,2). The location of the 
minuend and subsequent difference is Identified by FIELD2(201,4). 
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Subtract Register — Register 


0 7 8 9 11 12 13 15 


1 
SUBR @R,,@R, 7 | = Ea 


FUNCTION: Performs a binary subtraction of two one-word fields; either 


field may be in a general register or in memory. 


OPERAND 1: A one-word field located in the general register specified by 
Rj or in memory if indirect addressing is used, bit 8=1. This operand is 
subtracted from operand 2. 


OPERAND 2: A one-word field located in the general register specified by 
Ro or in memory if indirect addressing is used, bit 12=1. 


RESULTS: The resulting difference resides at the operand 2 location. The 
Condition register is affected as follows: 


e Bit 0 (overflow) is set if the result is less than -32,768 
or greater than +32,767. ; 
Bits 1-2 and 4-7 are cleared. 
e Bit 3 (link) is set if the result is greater than 65,535. 
e Subtracting 8000,, from 0000,, results in 8000_, and bit 

0 is set. 16 > PG 16 


EXAMPLE: SUBR @5,@0 


The value at the location specified in register 5 is subtracted from 
the value at the location specified in register 0. The difference re- 
places the minuend. 
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Subtract Two-Word 
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FUNCTION: Performs a binary subtraction of a two-word field in memory from 
a two-word field in two general registers or in memory. 


QPERAND 1: A two-word field in memory at the effective address. Addressing 
options to the base address M include indexing (Rj), indirect addressing 
(bit 8=1), or a combination of both. This operand is subtracted from 
operand 2. The effective address points to the most significant bits 

of the two-word field. 


OPERAND 2: A two-word field located in two general registers (the most 
significant bits in the register specified by Rp and the least significant 
bits in the register Rg+1) or in memory at the address if indirect addres- 
sing is used, bit 12=]. (Note: If register 7 is specified by Rg, the 
most significant bits are in register 7 and the least significant bits are 
in register 0.) 


RESULTS: The resulting difference resides at the operand 2 location. 
The Condition register is affected as follows: 


e Bit 0 ey) is set if the result is greater than +2312] 
or less than -23!, 

e Bits 1-2 and 4-7 are cleared. 

e Bit 3 (link) is set if the result is greater than +231-1, 

@ Subtracting 80000000) ¢ from 00000000;¢ results in 80000000)¢ 
and bit 0 jis set. 


EXAMPLE: SUBT  TAG(S5) ,2 


A two-word field identified by TAG(5) is subtracted from the contents of 
registers 2 and 3. The difference is held in the registers. 
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Zero and Add e 
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ZADK My (Ly Ry) »My (Ly ,R,) 


FUNCTION: Zeros out a field in memory, then performs an addition of a 
packed decimal field in memory and the zero field. The field lengths Ly 
and ) may vary from 0-255 bytes. 


OPERAND 1: A packed decimal field in memory; the field length, 0-255 

bytes, is specified by the value in the instruction. The operand address 
indicated by My may be indexed (R]), but indirect addressing is not allowed. 
The effective operand address points to the most significant bytes of the 
decimal field. 


QPERAND 2: A field in memory that is zeroed out before the addition. 
The field length, 0-255 bytes, is specified by the Lg value of the 
instruction. The field address indicated by Mpg may be indexed by (Ro), 
but no indirect addressing is allowed. The effective field address 
points to the most significant address of the field. 


RESULTS: The resulting field resides at the operand 2 location. The 
Following conditions can occur, depending on the values of Lo and Ly]- 


@e if Ly} is greater than Lo and the difference between L 
and Lz contains significant data, bit 0 of the Condition 
register is set. 

e If lL) = 0 and Ly = 0, bit 3 of the Condition register is set. 

if L} = 0, an add of zero is assumed. 

@ If Ly is greater than L;, zeros are used to make up the 
difference in field lengths. 


The Condition register is also affected as follows: 


@e Bit 0 is set if significant data is lost; bits 1-7 are cleared. 

e Bits | and 5 are set if results are plus; bits 0, 2-4, and 
6-7 are cleared. 

e Bits 2 and 6 are set if results are minus; bits 0-1, 3-5, and 
7 are cleared. 

e@e Bits 3 and 7 are set if results are zero; bits 0-2, and 4-6 
are cleared. 
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EXAMPLE: ZADK TAG2(50,4),TAGI (55,0) 


Initially, a 55-byte field identified by TAGI(55,0) is cleared to 
zero; then a 50-byte field identified by TAG2(50,4) is added to it. 
(See Results description for Condition register status.) 
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BIT-ORIENTED INSTRUCTIONS 


Mnemonic Code Name 
IBIT Invert Bit e 
RBIT Reset Bit e 
ROFR Reverse Off-Bit 
RONR Reverse On-Bit 
SBIT Set Bit e 
TBIT Test Bit e 
TOFR Test for Off-Bit 
TONR Test for On-Bit 
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Invert Bit e 
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FUNCTION: Invert (toggle) a bit in a one-byte field in memory. 


OPERAND 1: A one-byte field in memory. Addressing options to the base 
address M include indexing (R), indirect addressing (bit 8=1), or a com- 
bination of both. 


OPERAND 2: A 3-bit value in bits 13-15 of the instruction. This value 
specifies the position of the bit to be toggled and may range from 0-7; 
0 specifies the leftmost position and 7 the rightmost position. 


RESULTS: The resultant field resides at the operand | location. 


EXAMPLE: IBIT @TAG(4),3 


This instruction reverses the existing binary state of a specific bit 
in memory. @TAG(4) points to an 8-bit byte and 3 is the number of the 
bit (bits are numbered left to right, 0-7). 
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Reset Bit e 
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RBIT  @M(R), | ce ape fp 
: : 


FUNCTION: Resets a bit (to 0) in a one-byte field in memory. 


QPERAND 1: The one-byte field in memory. Addressing options to the base 
address M include indexing (R), indirect addressing (bit 8=1), or a 
combination of both. 

QPERAND 2: A 3-bit value in bits 13-15 of the instruction. This value 
specifies the position of the bit to be reset and may range from 0-7; 

0 specifies the leftmost position and 7 specifies the rightmost position. 


RESULTS: The resultant field resides at the operand | location. 


EXAMPLE: IBIT  @TAG(2),4 


Bit number 4 of an 8-bit byte located at @TAG(2) in memory is given the 
binary state of 0. 
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Reverse Off-Btt 


7.8 11 12 13 
ROFR Ry ,0R, [= Ts Bl | 


FUNCTION: Scans a one-word field, left to right, for the first off-bit, 
and increases another one~-word field by an amount equal to the position of 
the first off-bit (0-15). The first off-bit is then turned on. If no 
off-bit is found, the field is increased by a value of 16. Either field 
may be in a general register or in memory. 


QPERAND 1: A one-word field in the general re ister specified by R, OF 
in memory if indirect addressing is used, bit 5=1. This field is scanned 


for the first off-bit. 


QPERAND 2: A one-word field in the general register specified by Ro or 
in memory if indirect addressing is used, bit 12=1. The field is increased 
by a value equal to the position of the first off-bit in operand 1. 


RESULTS: The resultant operands reside at their original locations. 


EXAMPLE: ROFR @7,@2 


Register 7 contains an address of a 16-bit field which is scanned from 
left to right for a O-bit. If a O-bit is found, the bit position (0-15) 
determines the value to add to a one-word field located at an address 
specified in register 2. After this value is increased, the O-bit is set 
to. 1, 
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Reverse On-Bit 
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FUNCTION: Scans a one-word field, left to right, for the first on-bit, and 
increases another one-word field by an amount equal to the position of that 
first on-bit (0-15). The first on-bit is then turned off. If no on-bits 
are found, the field is increased by a value of 16. Either field may be 

in a general register or in memory. 


OPERAND 1: A one-word field located in the general register specified by 
R; or in memory if indirect addressing is used, bit 8=1. This field is 
scanned for the first on-bit. 


OPERAND 2: A one-word field located in the general register specified by 
Ro or in memory if indirect addressing is used, bit 12=1. This field is 
increased by a value equal to the position of the first on-bit in operand 
2. 


RESULTS: The resultant operands reside at their original locations. 


EXAMPLE: RONR @4,@6 


Register 4 contains the address of a 16-bit field which is scanned for 
an on-bit. Ifa I-bit is found, the binary position (0-15) of that bit 
determines the value (0-15) added to another one-word field at the 
location specified in register 6. After this field is increased in 
value, the state of the original bit is changed to a O-bit.. If no 
I-bit is found during the scan, the other field is increased by a 

value of 16. 
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Set Bit e@ 
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BIT @M(R) 1 ee: 
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FUNCTION: Sets a bit (to 1) in a one-byte field in memory. 

OPERAND 1: A one-byte field in memory. Addressing options to the base 
address M include indexing (R), indirect addressing (bit 8=1), or a 
combination of both. 

OPERAND 2: A 3-bit value in bits 13-15 of the instruction. This value 
specifies the position of the bit to be set and may range from 0-7; 0 
specifies the leftmost position and 7 the rightmost position. 


RESULTS: The resultant field resides at the operand | location. 


EXAMPLE: SBIT ®@TAG(2),7 


Turns on bit number 7 of an 8-bit byte at the location specified by 
@TAG(2). 


Aw 
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Test Btt e 
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FUNCTION: Tests a bit in a one-byte field in memory, and transfers the 
bit state (1 or 0) to bit 0 of the Condition register. 


OPERAND 1: The one-byte field in memory. Addressing options to the 
base address M include indexing (R), indirect addressing (bit 8=1), or 
a combination of both. 

OPERAND 2: A 3-bit value in bits 13-15 of the instruction; this value 
specifies the position of the bit in operand 2 and may range from 0-7; 
0 specifies the leftmost position and 7 the rightmost position. 


RESULTS: The result is reflected in the bit state of bit 0 in the Con- 
dition register. 


EXAMPLE: TBIT  @JTE(5),6 


The binary state of bit 6 of an 8-bit byte at a location specified by 
@JTE(5) is reproduced in bit O of the Condition register. 
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FOR MEMOREX INTERNAL USE ONLY 
Test for Off-Bit 


11 12 13 


ar FF 9 


FUNCTION: Scans a one-word field, left to right, for the first off-bit, 
and increases another one-word field by an amount equal to the position 
of that first off-bit (0-15). The first off-bit is not changed. If no 
off-bits are found, the field is increased by a value of 16. Either 
field may be in a general register or in memory. 


QOPERAND 1: A one-word field in the general register specified by Rj or 
in memory if indirect addressing is used, bit 8=1. This field is scanned 
for the first off-bit. 


OPERAND 2: A one-word field in the general register specified by Ro or 
in memory if indirect addressing is used, bit 12=1. This field is in- 
creased by an amount equal to the position of the first off-bit in 
operand |. 


RESULTS: The resultant operands reside at their original locations. 


EXAMPLE: TOFR @3,@1 


A 16-bit field at a location specified in register 3 is scanned left 

to right (0-15) for a O-bit. If none is found, the value at the location 

specified in register 1 is increased by 16. However, if a O-bit is found, 
the bit position (0-15) of that bit specifies the value added to the other 
field. 
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FOR MEMOREX INTERNAL USE ONLY 
Test for On-Bit 
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FUNCTION: Scans a one-word field, left to right, for the first on-bit, and 
increases another one-word field by an amount equal to the bit position of 
the first on-bit (0-15). The first on-bit is not changed. If no on-bits 
are found, the field is increased by a value of 16. Either field may be 
in a general register or in memory. 


OPERAND 1: A one-word field in the general register specified by Ry, or in 
memory if indirect addressing is used, bit 8=1. This field is scanned for 
the first on-bit. 


OPERAND 2: A one-word field in the general register specified by Ro or in 
memory if indirect addressing is used, bit 12=1. This field is increased 
by an amount equal to the position of the first on-bit in operand 1. 


RESULTS: The resultant operands reside at their original locations. 


EXAMPLE: TONR @2,@3 


A 16-bit field at a location specified in register 2 is scanned left to 
right (0-15) for a I-bit. If none is found, the value at the location 
specified in register 3 is increased by 16. If a I-bit is found, the 
binary position (0-15) of that bit corresponds to the value added to the 
other field. 
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BOOLEAN LOGIC INSTRUCTIONS 


Mnemonic Code 


EORD 
EORI 
EORM 
EOR 

EORR 
1ORD 
iORI 
1ORM 
IOR 

IORR 
ANDD 
ANDI 
ANDM 
AND 

ANDR 
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Name 


Exclusive OR Direct 

Exclusive OR Immediate 

Exclusive OR Memory — Memory 
Exclusive OR Memory — Register 
Exclusive OR Register — Register 
Inclusive OR Direct 

Inclusive OR Immediate 

Inclusive OR Memory — Memory 
Inclusive OR Memory — Register 
Inclusive OR Register — Register 


Logical 
Logical 
Logical 
Logical 
Logical 
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Product Direct 

Product Immediate 

Product Memory — Memory 
Product Memory — Register 
Product Register — Register 
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Exelustve OR Direct 


0 7 8 9 11.12 13 15 


EORD 1(Ry) 0 ee ee 


FUNCTION: Performs an exclusive OR of a one-word immediate value* and a 
one-word field in a general register or in memory. Corresponding bits 
in each operand are compared. If the bits are unlike, the corresponding 
resultant bit is 1; if the bits are the same, the resultant bit is 0. 


 OPERAND 1: A 16-bit immediate value in bits 16-31 of the instruction; 
the value may range from 0 to 65,535. 


*Indexing may be specified for operand 1. In this case, operand l fs ; 
derived by adding the | value and the general register contents specified: 
by Ry; no check for overflow or link is made during the indexing. 


OPERAND 2: A one-word field in the general register specified by Ro or 
' In memory if Indirect addressing is used, bit 12=1. 


RESULTS: The resulting OR operand resides at the operand 2 location. 


EXAMPLE: ORD  65501(2) ,@5 
An exclusive OR is performed between the value of 65,501(2) and the 


16-bit field at a location specified by the address in register 5; this 
address is also the address of the result. 


3H49* 2999,001 


FOR MEMOREX INTERNAL USE ONLY 


Exclusive OR Immediate 


11 12 13 


FUNCTION: Performs an exclusive OR between a 4-bit immediate value held 

in the instruction and a one-word field in a general register or in 

memory. Corresponding bits in each operand are compared. If the bits 

are unlike, the resultant bit is 1; if the bits are the same, the resultant 
bit is 0. 


OPERAND 1: A 4-bit unsigned value located in bits 8-11 of the instruction; 
the value may range from 0-15. The | value is ORed to operand 2 in bit 
positions 12-15 with bits O-11 zeros. 


OPERAND 2: A one-word field in the general register ‘specified by Ror in 
memory if indirect addressing is used, bit 12=1. 


RESULTS: The resulting OR operand resides at the operand 2 location. 


EXAMPLE: EORI 13,@1 


An exclusive OR is performed on the immediate value of 13 and the 16-bit 
field at a location specified by the address in register 1; this address 
is also the address of the result. 
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Exelusive OR Memory — Memory 


0 7 8 9 11 12 13 
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FUNCTION: Performs an exclusive OR of two one-word fields in memory. 
Corresponding bits in each operand are compared. If the bits are unlike, 
the corresponding resultant bit is 1; if the bits are the same, the 
resultant bit is 0. 


OPERAND 1: A one-word field in memory. Addressing options to the base 
address My include indexing (Ry), indirect addressing (bit 8=1), or a 
combination of both. 


OPERAND 2: Same as oer ] except use Mo, Rg, and bit 12=1. 


RESULTS: The resulting OR operand resides at the operand 2 location. 


EXAMPLE: EORM  @TAG(2),@DTN(4) 
An exclusive OR is performed between a 16-bit field at the address 


identified by @TAG(2) and the 16-bit field at the address identified by 
@DTN(4). The result ts stored at the address specified by @DTN(4). 
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Exclusive OR Memory — Register 
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FUNCTION: Performs an exclusive OR of a one-word field in memory and a one- 
word field in a general register or in memory. Corresponding bits in each 
operand are compared. If the bits are unlike, the corresponding resultant 
bit is 1; if the bits are the same, the resultant bit is 0. 


OPERAND 1: A one-word field in memory. Addressing options to the base 
address M include indexing (R;]), indirect addressing (bit 8=1), or a 
combination of both. 


OPERAND 2: A one-word field in the general register specified by Ro or 
in memory if indirect addressing is used, bit 12=1. 


RESULTS: The resulting OR operand resides at the operand 2 location. 


EXAMPLE: EOR @TAG(3),@5 


An exclusive OR is performed between a 16-bit field at the address 
identified by @TAG(3) and the 16-bit field at the address identified in 
register 5. The address specified in register 5 is also that of the 
result. | . 
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-Exelustve OR Register — Register 


0 7 8 9 11 12 13 
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FUNCTION: Performs an exclusive OR of two one-word fields; either field 
may be in a register or in memory. Corresponding bits in each operand 
are compared. If the bits are unlike, the corresponding resultant bit 
is 1; if the bits are the same, the resultant bit is 0. 


OPERAND 1: A one-word field in the general register specified by Rj or in 
memory if indirect addressing is used, bit 8=1. 


OPERAND 2: Same as operand 1 except use Rg and bit 12=1. 


RESULTS: .The resulting OR operand resides at the operand 2 location. 


EXAMPLE: EORR @4,@7 


An exclusive OR is performed between two 16-bit fields, one of which is 
at the address specified in register 4 and the other at the address 
specified in register 7. The result is placed at the address specified 
in register 7. 


3-53 : 2999 .001 


FOR MEMOREX INTERNAL USE ONLY 


Inelustve OR Direct 
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FUNCTION: Performs an inclusive OR of a one-word immediate value* and 

a one-word field in a general register or in memory. Corresponding bits 
in each operand are compared. If either of the bits is 1 or if both of 
the bits are 1, the corresponding resultant bit is 1. If both bits are 
0, the resultant bit is 0. 


_ OPERAND 1: A 16-bit immediate value in bIlts 16-31 of the [fnstruction; 
the value may range from 0-65,535. 


| *Indexing may be specified for operand 1. In this case, operand 1 is 
derived by adding the | value and the general register contents specified 
by Ry; no check for overflow or link [ts made during the indexing. 


OPERAND 2: A one-word field in the general register specified by Ro 
or in memory if indirect addressing is used, bit 12=]. 


RESULTS: The resulting OR operand resides at the operand 2 location. 


EXAMPLE: IORD 64201(3) ,@5 


An inclusive OR is performed on the immediate value 64,201, as modified 
by the contents of register 3, and the 16-bit field at the address 
specified in register 5. This address is also the address of the 
result. 
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Inelustve OR Immediate 


0 7 8 11.12 13 15 
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FUNCTION: Performs an inclusive OR between a 4-bit immediate value held in 
the instruction and a one-word field in a general register or in memory. 
Corresponding bits in each operand are compared. If either of the bits is 
l or both bits are 1, the corresponding resultant bit is 1. If both bits 
are 0, the resultant bit is 0. 


OPERAND 1: A 4-bit unsigned value located tn bits 8-11 of the instruction; 
the value may range from 0-15. The | value is ORed to operand 2 in bit 
positions 12-15 with bits O-11 zeros. 


OPERAND 2: A one-word field in the general register specified by Ror 
In memory .if indirect addressing is used, bit 12=1. 


~ RESULTS: The resulting OR operand resides at the operand 2 location. 


EXAMPLE: IORI 10,@3 


An inclusive OR is performed on the immediate value 10 and the 16-bit 
field at the address in register 3. The result is stored at the address 
in register 3. 
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Inelusive OR Memory — Memory 
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FUNCTION: Performs an inclusive OR of two one-word fields in memory. 
Corresponding bits in each operand are compared. If either of the bits 
is 1 or both of the bits are 1, the corresponding resultant bit is 1. If 
both bits are 0, the resultant bit is 0. . 

OPERAND 1: A one-word field in memory. Addressing options to the base 
address M, include indexing (Ri), indirect addressing (bit 8=1), or a 
combination of both. 

OPERAND 2: Same as operand | except use Mo, Ro» and bit 12=1. 


RESULTS: The resulting OR operand resides at the operand 2 location. 


EXAMPLE: ORM @HERE(2) ,@TAG(1) 


Performs an inclusive OR between two 16-bit fields. @TAG(1) represents 
the address of the results. 
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Inelustve OR Memory — Register 


O- 789 111213 15 


1OR @M(R1),@Ro 


FUNCTION: Performs an inclusive OR of a one-word field in memory and a 
one-word field in a general register or in memory. Corresponding bits in 
each operand are compared. If either of the bits is 1 or if both of the 
bits are 1, the corresponding resultant bit is 1. If both bits are 0, the 
resultant bit is 0. 


OPERAND 1: A one-word field in memory. Addressing options to the base 
address M Include Indexing (R}), Indirect addressing (bit 8=1), or a 
combination of both. . 


OPERAND 2: A one-word field In the general register specified by Rg or 
in memory {tf indirect addressing is used, bit 12=1. 


RESULTS: The resulting OR operand resides at the operand 2 location. 


EXAMPLE: 10R @TAG(3) ,@7 
An inclusive OR is performed on two 16-bit fields, one at the address 


identified by @TAG(3) and the other at the address specified in register 7. 
The address in register 7 is the address of the result. 
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Inclusive OR Register -- Kegtster 
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FUNCTION: Performs an inclusive OR on two one-word fields; either field 
may be in a register or in memory. Corresponding bits in each operand are 
compared. If either of the bits is 1 or if both of the bits are 1, the 
corresponding resultant bit is 1. If both bits are 0, the resultant bit 
is 0. 


OPERAND 1: A one-word field located in the general register specified 
by R,; or in memory if indirect addressing is used, bit 8=1. 


OPERAND 2: Same as operand | except use Ro and bit 121, 


RESULTS: The resulting OR operand resides at the operand 2 location. 


EXAMPLE: [ORR @5,@6 


An inclusive OR is performed between the two l6-bit fields at the addresses 
specified in registers 5 and 6. Results are placed at the address in 
register 6. 
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Logteal Produet Direct 
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AND 1(Ry) @Re ae 
a a 


FUNCTION: Performs a logical product of a one-word immediate value* and 
a one-word field in a general register or in memory. Corresponding bits 
in each operand are compared. If both bits are 1, the corresponding 
resultant bit is 1; in all other cases, the resultant bit is 0. 


/OPERAND 1: A 16-bit immediate value In bits 16-31 of the instruction; the 
value may range from 0-65,535. 


*Indexing may be specified for operand 1. In this case, operand | is de- 
rived by adding the | value and the general register contents specified 
by Ry; no check for overflow or link is made during the Indexing. 


~ OPERAND 2: A one-word field in the general register specified by Ry or 
"in memory if indirect addressing is used, bit 12=1]. 


RESULTS: The resulting field resides at the operand 2 location. 


EXAMPLE: ANDD 40000(3) ,@1 
A logical product operation is performed peice 40,000, as modified by the 


contents of register 3, and the l6-bit field at the address in register 1. 
This address is also the address of the results. 
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Logical Product Immediate 
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FUNCTION: Performs a logical product of a 4-bit immediate value and a 
one-word field in a general register or in memory. Corresponding bits 
in each operand are compared. If both bits are 1, the corresponding 
resultant bit is 1; in all other cases the resultant bit is 0. 


OPERAND 1: A 4-bit unsigned value in bits 8-11 of the instruction; the 
value may range from 0-15. The | value is compared against operand 2 
in bit positions 12-15 and bits 0-11 are zeros. 


OPERAND 2: A one-word field located in the general register specified 
by R or in memory if indirect addressing is specified, bit 12=1. 


RESULTS: The resulting field resides at the operand 2 location. 


EXAMPLE: ANDI 14,@2 
A logical product is performed on the immediate value 14 and the 16-bit 


field at the address specified in register 2. This address is also the 
address of the result. 
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Logteal Produet Memory -— Memory 
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FUNCTION: Performs a logical product of two one-word fields in memory. 
Corresponding bits in each operand are compared. If both bits are 1, 
the corresponding resultant bit is 1; in all other cases the resultant 
bit is 0. 


OPERAND 1: A one-word field in memory. Addressing options to the base 
address M, include indexing (Ry ), indirect addressing (bit 8=1), or a 
combination of both. 


OPERAND 2: Same as operand | except use Mo, Ro, and bit 12=1. 


RESULTS: The resulting field resides at the operand 2 location. 


EXAMPLE: ANDM @HOLD(7) ,@SPIKE (2) 
A logical product is performed between a l6-bit field at the address 


identified by @HOLD(7) and the 16-bit field at the address specified by 
@SPIKE(2). The result is stored at the @SPIKE(2) address. 


3-61 2999.001 


FOR MEMOREX INTERNAL USE ONLY 


Logteal Product Memory — Register 


0 7 8 Q 11.12 13 15 


aNd @N(RI) Ry hastened eae eam) 


FUNCTION: Performs a logical product of a one-word field in memory and a 
one-word field in a general register or in memory. Corresponding bits in 
each operand are compared. If both bits are |, the corresponding resultant 
bit is 1; in all other cases the resultant bit is 0. 


OPERAND 1: A one-word field in memory. Addressing options to the base 
address M include indexing (Ry), indirect addressing (bit 8=1), or a com- 
bination of both. 


OPERAND 2: A one-word field in the general register specified by Rg or in 
memory if indirect addressing is used, bit 12=]. . 


RESULTS: The resulting field resides at the operand 2 location. 


EXAMPLE: AND  @TAG(3),@5 


Performs a logical product between two 16-bit fields. The results are 
stored at the address specified in register 5. 
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FOR MEMOREX INTERNAL USE ONLY 


Logteal Product Register — Register 


0 7 8 9 11 12 13 


mo ae, ale 


FUNCTION: Performs a logical product of two one-word fields; either field 
may be in a register or in memory. Corresponding bits in each operand are 
compared. If both bits are 1, the corresponding resultant bit is 1; in 
all other cases the resultant bit is 0. 


OPERAND 1: A one-word field located in the general register specified by 
Ry or in memory if indirect addressing is used, bit 8=1. 


OPERAND 2: A one-word field located in the general register specified by 
Ro or in memory if indirect addressing is used, bit 12=1. 


RESULTS: The resulting field resides at the operand 2 location. 


EXAMPLE: ANDR  @7,@4 


A logical product is performed between the 16-bit field at the address 
specified in register 7 and the 16-bit field at the address specified 
in register 4. The address in register 4 is the address of the results. 


3-63 2999.001 


BRANCHING INSTRUCTIONS 


Mnemonic Code 


3-64 


FOR MEMOREX INTERNAL USE ONLY 


Name 


Branch Add One 
Branch Add Two 


if Register Not Zero 


on Condition Register False 
on Condition Register True 


to Address in Register 


Minus - Forward 
Minus ~ Backward 
Not Zero - Forward 
Not Zero - Backward 
Plus - Forward 

Plus - Backward 
Zero ~- Forward 

Zero ~ Backward 


Branch and Save Return 
Branch if Bit Off 
Branch if Bit On 
Branch 

Branch if Register Zero 
Branch 

Branch 

Branch Subtract One 
Branch Subtract Two 
Branch 

Branch Unconditional 
Skip if Register 

Skip if Register 

Skip if Register 

Skip if Register 

Skip if Register 

Skip if Register 

Skip if Register 

Skip if Register 

Skip 


on Condition Register False - Forward 
on Condition Register False - Backward 
on Condition Register True - Forward 
on Condition Register True ~ Backward 
Unconditional - Forward 

Unconditional - Backward 


2999.001 


FOR MEMOREX INTERNAL USE ONLY 


Branch 


B eH(R) 


_ FUNCTION: Branches unconditionally to a specified memory location. 
This instruction differs from BCH which uses pre=indexing; B 
uses post-indexing. 


QPERAND: A 16-bit value in bits 16-31 of the instruction that may 
range from 0-65,535. It is the memory location to which the pro- 
gram branches. Addressing options to the base address M include 
indexing (R), indirect addressing (bit 8=1), or a combination of 
both. . 


we 


EXAMPLE: B  @TAG(4) 


The program branches unconditionally to the address identified by 
@TAG(4). ‘ 


3-65 : 2999.0011 


FOR MEMOREX INTERNAL USE ONLY 
Branch Add One 


0 7 8 9 .. 11 12 13 15 


BA] @M(R,) ,@Rp 


FUNCTION: Tests a one-word field in a general register or in memory 
for a zero value; if the field is zero, the next instruction in the 
program is executed. If the field tested is not zero, it is increased 
by a value of 1, and the program branches to a specified memory 
location. 


OPERAND 1: A 16-bit value in bits 16-31 of the instruction. It is the 
memory location to which the program branches if the tested field is 
‘not zero. Addressing options to the base address M include indexing 
(R;), indirect addressing (bit 8=1), or a combination of both. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by Rp or in memory if indirect addressing is used, bit 12=1. 


EXAMPLE: BAI TAG(3),@2 


The 16-bit field is tested at the address in register 2; if the field 
is non-zero, a value of | is added to the field and the program 
branches to the address identified by TAG(3). If the field tested 

is zero, the program continues with the next instruction. 


3-66 2999.001 


| FOR MEMOREX INTERNAL USE ONLY 
Branch Add Two 


0 78 9 111213 15 


BAZ @M(R}),@R, 


FUNCTION: Tests a one-word field in a general register or in memory 
for a zero value; if the field is zero, the next instruction in the 
program is executed. If the field tested is not zero, it is increased 
by a value of 2, and the program branches to a specified memory 
location. 


OPERAND 1: A 16-bit value in bits 16-31 of the instruction. It is the 
memory location to which the program branches if the tested field is not 
zero. Addressing options to the base address M include indexing (R;), 
indirect addressing (bit 8=1), or a combination of both. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by Ro or in EMORY if- indirect addressing is used, bit 
12=1. 


EXAMPLE: BA2 TAG(4),@1 


The 16-bit field is tested at the address in register 1; if the field 
is non-zero, a value of 2 is added to this field and the program 
branches to the address identified by TAG(4). if the field is zero 
when the test is made, no branch is Peprorned and the program con- 
tinues with the next instruction. 


3-67 : 29991001. 


FOR MEMOREX INTERNAL USE ONLY 


Braneh and Save Return 


0 7 8 9 11 12 13 15 


BSR @M(R)) ,@R, 


FUNCTION: Branches unconditionally to a specified memory address, 
storing the address of the next instruction in a general register. 
The address stored (return address) is the current program address 
plus four bytes. - 


OPERAND 1: A 16-bit value in bits 16-31 of the instruction. It is the 
memory location to which the program branches. Addressing options to 
the base address M include indexing (R}), indirect addressing (bit 
8=1), or a combination of both. | 


OPERAND 2: The general register specified by Rp, or the memory field 
if indirect addressing is used (bit 12=1), that upon completion con- 
tains the return address. 


EXAMPLE: BSR TAG(6),5 


Branches unconditionally to the address identified by TAG(6) and 
stores the next instruction address (current program address plus 
four bytes) into register 5. After the instructions beginning at 
TAG(6) are executed, the program continues with the instruction at 
the address in register 5. : 


3-68 : 2999.001 


, FOR MEMOREX INTERNAL USE ONLY 
Branch tf Bit Off 


: a dap 
BOF aM UR) 


FUNCTION: Branches to a specified memory location if the bit tested 
in a general register is off. If the bit is on, the next instruction 
in the program is executed. 


OPERAND 1: The operand is composed of two parts: the general register 
tested is specified by R, and the 16-bit value contained in M is the 
memory address to which the program branches. Addressing options to the 
base address M include indirect addressing (bit 8=1), but not indexing. 


~ OPERAND 2: A 4-bit value in bits 12-15 of the instruction. This value 
specifies the position of the bit to be tested in the general register 
and may range from 1-15. 


EXAMPLE: BOF @TAG(3),14 


Branches to the address identified by @TAG(3) if bit 14 of register 3 
is off (0). If bit 14 is on (1), the next instruction is read. 


3-69 7 : 2999.001 


FOR MEMOREX INTERNAL USE ONLY 


Branch tf Bit On 


9 11 12 15 


BON @M(R),! 


FUNCTION: Branches to a specified memory location if. the bit tested in 
a general register is on. If the bit is off, the next instruction in 
the program is executed. 


OPERAND 1: The operand is composed of two parts: the general register 
tested is specified by R, and the 16-bit value contained in M jis the 

memory address to which the program branches. Addressing options to the 
base address M include indirect addressing (bit 8=1), but not indexing. 


OPERAND 2: A 4-bit value in bits 12-15 of the instruction. This 
value specifies the position of the bit to be tested in the general 
register and may range from 1-15. 


EXAMPLE: BON TAG(5),9 


This instruction tests bit 9 in register 5. If bit 9 is on (1), the 
program branches to the address identified by TAG. Otherwise, no branch 


is made and the next instruction pointed to by the program counter 
is read. 


3-70 | 2999.00] 


FOR MEMOREX INTERNAL USE ONLY 


Branch tf Register is Not Zero 


BRN @M(R}) ,@Ro 


FUNCTION: Branches to a specified memory location if the general regis- 
ter tested does not contain all zeros. If the register contains all 
zeros, the next instruction in the program is executed. 


OPERAND |: A 16-bit value in bits 16-31 of the instruction. It fis the 
memory location to which the program branches if the general register 
does not contain all zeros. Addressing options to the base address 

M include indexing (Rj), indirect addressing (bit 8=1), or a com- 
bination of both. 


QPERAND 2: The value tested; a one-word field in the general register 
- specified by Ry or in memory if indirect addressing is used, bit 12=1. 


EXAMPLE: BRN TAG(2),5 
The program branches to the address specified by TAG(2) if the contents 


of register 5 are not zeros; if the contents are zeros, the next 
instruction is. read. 


3-71 : 2999.001. 


FOR MEMOREX INTERNAL USE ONLY 


Eranch if Register ts Zero 


0 7 8 9 11 12 13 15 


ese [tls [i= |} 


FUNCTION: Branches to a specified memory location if the general register 
tested contains all zeros. If the register does not contain all zeros, 
the next instruction in the program is executed. 

OPERAND 1: A 16-bit value in bits 16-31 of the instruction. It is the ‘ 
memory location to which the program branches if the general register 
contains all zeros. Addressing options to the base address M include 
indexing (Rj), indirect addressing (bit 8=1), or a combination of both. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by Ro or in memory if indirect addressing is used, bit 12=1. 


EXAMPLE: BRZ TAG,6 


The program branches to the address of TAG if the contents of register 
6 are all zeros; if the contents are not all zeros, the next instruction 
is read. 


ade 2999.001 


FOR MEMOREX INTERNAL USE ONLY 


Braneh on Condition Register False 


BCF @M(R), | 


FUNCTION: Branches to a specified memory location if a designated Con- 
dition register bit is off. If the bit is on, the next instruction in 
the program is executed. 


OPERAND 1: A 16-bit value in bits 16-31 of the instruction. It is the 
memory location to which the program branches {if the designated Condition 
register bit is on. Addressing options to the base address M include 
indexing (Rj), indirect addressing (bit 8=1), or a combination of both. 


OPERAND 2: A 4-bit value In bits 12-15 of the instruction. The value 


specifies the position of the bit to be tested in the Condition register 
and may range from 0-15. 


EXAMPLE: BCF @TAG(7),11 


Branches to the location specified by @TAG(7) if bit 11 of the Condition 
register is off (0). If bit 11 is on (1), the next instruction is read. 


3-73 2999.001 


FOR MEMOREX INTERNAL USE ONLY 


Branch on Condition Register True 


BCT  @M(R),|I 


FUNCTION: Branches to a specified memory location if a designated Con- 
dition register bit is on. If the bit is off the next instruction in 
the program is executed. 


OPERAND 1: A 16-bit value in bits 16-31 of the instruction. It is the , 
memory location to which the program branches if the designated Condi- 
tion register bit is on. Addressing options to the base address M 
include indexing (R), indirect addressing (bit 8=1), or a combination 

of both. 


OPERAND 2: A 4-bit value in bits 12-15 of the instruction. The value 


specifies the position of the bit to be tested in the Condition 
register and may range from 0-15. 


EXAMPLE: BCT  @TAG(3),8 - 
Branches to the address identified by @TAG(3) if bit 8 of the Condition 


register is on (1). If the bit is off (0), no branch is made and the 
-next instruction is read. 


3-74 2999.001 


| FOR MEMOREX INTERNAL USE ONLY 
Branch Subtract One 


0 7 8 9 11.12 13 15 


B81 OM(R}) 0%) ee ee 
a ere 


FUNCTION: Tests a one-word field in a general register or in memory 
for a zero value; if the field is zero, the next instruction in the 
- program is executed. If the field tested is not zero, it is de- 
creased by a value of 1, and the program branches to a specified 
memory location. 


OPERAND 1: A 16-bit value in bits 16-31 of the instruction. It is 
the memory location to which the program branches if the tested field 
is not zero. Addressing options to the base address M include in- 
dexing (R}), indirect addressing (bit 8=1), or a combination of both. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by Ro or in memory if indirect addressing is used, bit 
12=1. 


EXAMPLE: BSI @TAG(5),@2 


Tests l6-bit field at the address in register 2. If the field 

contains a non-zero value, a branch is made to the address identified 
by @TAG(5), and the field value is decreased by 1. If the tested field 
is zero, the next instruction is read. . 


a 2999.001 


FOR MEMOREX INTERNAL USE ONLY 


Branch Subtract Two 


0 7 8 9 11 12 13 15 


Pe af [8] Re | 
BS2 @M(R,) ,@R, 


FUNCTION: Tests a one-word field in a general register or in memory 
for a zero value; if the field is zero, the next instruction in the 
program is executed. If the field tested is not zero, it is decreased 
by a value of 2 and the program jumps to a specified memory location. 


OPERAND 1: A 16-bit value in bits 16-31 of the instruction. It is the 
memory location to which the program jumps if the tested field is not 
zero. Addressing options to the base address M include indexing (R)), 
indirect addressing (bit 8=1), or a combination of both. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by Ry or in memory if indirect addressing is used, bit 12=1]. 


EXAMPLE: BS2 @TAG(5) ,@2 


Same as BSI, but decreases value in tested field by 2 after branch is 
made. 


3-76 -2999.001 


FOR MEMOREX INTERNAL USE ONLY 


Branch to Address in Register 


0 789 #21112 15 


BR @R 


FUNCTION: Causes an unconditional branch to a specified memory 
location. a 


OPERAND: A 3-bit unsigned value in bits 9-1] of the instruction. It 
points to the address to which the Program jumps. The address may be in 


the general register specified by R or in RINGO), if indirect ad- 
dressing is used, bit 8=1. 


EXAMPLE: BR 4 


Branches to the location specified in register 4. 


3-77 | 2999.001 


FOR MEMOREX INTERNAL USE ONLY 


Branch Uneondtttonal 


BCH  @M(R) 


FUNCTION: Branches unconditionally to a specified memory location. 
This instruction differs from B which uses post-indexing; BCH uses 
pre-indexing. 


OPERAND: A 16-bit value in bits 16-31] of the instruction. It is the 
memory location to which the program jumps. Addressing options to the 
base address M include indexing (R), indirect addressing (bit 8=1), 

or a combination of both. 


EXAMPLE: BCH @TAG(5) 


Branches to the address identified by @TAG(5). The value of TAG is 
added to the contents of register 5; the address formed is the address 
of an address to which the program will branch (this is the pre- 
indexing technique). ; 


3-78 . 2999.001 


FOR MEMOREX INTERNAL USE ONLY 
Skip if Register Minus - Forward 


0 = 78 111213 15 


tw ft 


SRMF 1 ,R 


FUNCTION: Skips forward a specified number of words if the register 
-contents tested are minus. If the register contents are plus, the next 
instruction in the program is executed. ™ . 


OPERAND 1: A 4-bit unsigned value in bits 8-11 of the instruction. 
This value specifies the number of words to skip and may range from 0-15. : 
The value is multiplied by 2 and added to the current program address. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by R. | | a | | 


EXAMPLE: SRMF  TAG,3 


Tests the contents of register 3. If negative, skip to instruction 
located at TAG; if positive or zero, the next instruction is read. 


3°79°° 2999.00] 


° 


FOR MEMOREX INTERNAL USE ONLY 


Skip tf Register Minus - Backward 


0 7 8 11 12 13 15 


SRMB-I,R 


FUNCTION: Skips back a specified number of words if the register contents 
tested are minus. If the register contents are plus, the next instruc- 
tion in the program is executed. 


OPERAND 1: A 4-bit unsigned value in bits 8-11 of the instruction. 
This value spectfies the number of words to skip and may range from 
0-15. The value is multiplied by 2 and subtracted from the current 
program address. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by R. 


EXAMPLE: SRMB_ TAG,3 


Tests the contents of register 3. If negative, skip to instruction 
located at TAG; if positive or zero, the next instruction is read. 


3-80 2999 .001 


FOR MEMOREX INTERNAL USE ONLY 


Skip tf Register Not Zero - Forward 


0 7.8 11 12 13 15 
SRNF 1,R . 


FUNCTION: Skips forward a specified number of words if the register con- 
tents tested are not zero. If the register does contain all zeros, the 
next instruction in the program is executed. 


OPERAND 1: A 4-bit unsigned value in bits 8-11 of the instruction. 
This value specifies the number of words to skip and may range from 


0-15. The value is multiplied by 2 and added to the current program 
address. . 


OPERAND 2: The value tested; a one-word field in the general register 
specified. by R. 


EXAMPLE: SRNF  TAG,2 


Tests the contents of register 2. If non-zero, skip to instruction 
located at TAG; if zero, read next instruction. 


3-81 | —-2999.001 


FOR MEMOREX INTERNAL USE ONLY 


Skip if Regtster Not Zero - Backward 


0 7 8 11 12 13 15 


SRNB 1,R 


FUNCTION: Skips back a specified number of words if the register contents 
tested are not zero. If the register does contain all zeros, the next 
instruction in the program is executed. 


OPERAND 1: A 4-bit unsigned value in bits 8-11 of the instruction. 
This value specifies the number of words to skip and may range from 0-15. 
The value is multiplied by 2 and added to the current program address. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by R. 


EXAMPLE: SRNB  TAG,2 


Tests the contents of register 2. If non-zero, skip to instruction 
located at TAG; if zero, read next instruction. 


3-82 . 2999 .001 


FOR MEMOREX INTERNAL USE ONLY 


Sktp tf Register Plus - Forward 


0 7 8 11 12 13 15 


 SRPF oI,R 


FUNCTION: Skips forward a specified number of words if the register 
- contents tested are plus. If the register contents are minus, the 
next Instruction in the program is executed. 


OPERAND 1: A 4-bit unsigned value in bits 8-11 of the instruction. This 
value specifies the number of words to skip and may range from 0-15. 
The value is multiplied by 2 and added to the current program address. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by R. 


EXAMPLE: SRPF TAG,4 
Tests the value in register 4. If positive, skips to the instruction | 


at location TAG; if not positive, the next instruction is read. TAG 
must be within 15 words of SRP. 


3-83 : 2999.00] 


FOR MEMOREX INTERNAL USE ONLY 


Skip if Regteter Plus - Backward 


SRPBI,R 


FUNCTION: Skips back a specified number of words if the register contents 
tested are plus. If the register contents are minus, the next instruc- 
tion in the program is executed. 


OPERAND 1: A 4-bit unsigned value in bits 8-11 of the instruction. This 
value specifies the number of words to skip and may range from 0-15. 

The value is multiplied by 2 and subtracted from the current program 
address. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by R. 


EXAMPLE: SRPB- TAG,4 
Tests the value in register 4. If positive, skips to. the instruction 


at location TAG; if not positive, the next instruction is’ read. TAG 
must be within 15 words of SRP. 
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FOR MEMOREX INTERNAL USE ONLY 


Sktp tf Regtster Zero - Forward 


0 :. 7 8 111213 15 


SRZF 1,R 


FUNCTION: . Skips forward a specified number of words if the register 
tested contains all zeros. If the register does not contain all zeros, the 
next instruction in the program is executed. 


OPERAND_1: A 4-bit unsigned value in bits 8-11 of the instruction. This 
value specifies the number of words to skip and may range from 0-15. 
The value is multiplied by 2 and added to the current program address. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by R.- 


EXAMPLE: SRZF TAG,5 
Tests the value in register.5. If all zeros, read the next instruction 


at location TAG; if not all zeros, the next instruction is read. TAG 
must be within Ts words of SRZ. 


3-85 2999.00] 


FOR MEMOREX INTERNAL USE ONLY 


Sktp tf Register Zero - Backward 


SRZB. I,R 


FUNCTION: Skips back a specified number of words if the register tested 
contains all zeros. If the register does not contain all zeros, the next 
instruction in the program is executed. 


OPERAND 1: A 4-bit unsigned value in bits 8-11 of the instruction. 

This value specifies the number of words to skip and may range from 0-15. 
The value is multiplied by 2 and subtracted from the current program 
address. 


OPERAND 2: The value tested; a one-word field in the general register 
specified by R. 
EXAMPLE: SRZB  TAG,5 

Tests the value in register 5. If all zeros, read the next instruction 


at location TAG; if not all zeros, the next instruction is read. TAG 
must be within 15 words of SRZ. 


3-86 | 2999 .001 


FOR MEMOREX INTERNAL USE ONLY 


Skip on Condition Register False - Forward 


FUNCTION: Skips forward a specified number of words if the appropriate 
Condition register bit Is off. If the bit is on, the next instruction 
in the program is executed. 


— QPERAND 1: A 4-bit unsigned value in bits 8-11 of the instruction. 
This value specifies the number of words to skip and may range from 0-15. 
It is multiplied by 2 and added to the current program address. 


OPERAND 2: ‘A 4-bit value in bits 12-15 of the instruction.- This value 
specifies the position of the bit tested for ork in the Condition register 
and may. range from 0-15. 


EXAMPLE: SCFF 12,3 | 
If bit 3 (equal bit) in the Condition register is off, the program will 


skip forward in the program 12 words (24 bytes). If bit 3 is on, the next 
instruction in the program is executed. 


3-87 , 2999 .001 


FOR MEMOREX INTERNAL USE ONLY 
Skip on Condttton Regtster False - Backward 


0 7 8 11 12 15 


FUNCTION: Skips back a specified number of words if the appropriate 
Condition register bit is off. If the bit is on, the next instruction 
in the program is executed. 


OPERAND 1: A 4=-bit unsigned value in bits 8-11 of the instruction. 
This value specifies the number of words to skip and may range from 0-15. 
Is multiplied by 2 and subtracted from the current program address. 


QPERAND 2: A 4-bit value in bits 12-15 of the instruction. This value 
specifies the position of the bit tested for off in the Condition register 
and may range from 0-15. 


EXAMPLE: SCFB 12,3 
If bit 3 (equal bit) in the Condition register is off, the program 


will skip back in the program 12 words (24 bytes). If bit 3 is on, 
the next instruction in the program is executed. 


3-88 | 2999.001 


FOR MEMOREX INTERNAL USE ONLY 


Sktp on Condition Regtster True - Forward 


FUNCTION: Skips: forward a specified number of words if the appropriate 
Condition register bit is on. If the bit is off, the next instruction 
in the program is executed. , 


OPERAND 1: A h-bit unsigned value in bits 8-11 of the instruction. 
This value specifies the number of words to skip and may range from 0-15. 
It is multiplied by 2 and added to the current program address. 


QPERAND 2: A 4-bit value in bits 12-15 of the instruction. This value 
specifies the position of the bit tested for on in the Condition 
register and may range from 0-15. 


EXAMPLE: SCTF TAG,0 
Assume that TAG is six words ahead of this instruction. If bit 0 
(overflow bit) in the Condition register is on, the program will skip 


six words (12 bytes) forward to TAG. If bit 0 is off, the next instruction 
in the program is executed. 
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FOR MEMOREX INTERNAL USE ONLY 


Skip on Condition Register True - Backward 


FUNCTION: Skips back a specified number of words if the appropriate 
Condition register bit is on. If the bit is off, the next instruction 
in the program is executed. 


OPERAND 1: A 4-bit unsigned value in bits 8-11 of the instruction. 
This value specifies the number of words to skip and may range from 
0-15. It fs multiplied by 2 and subtracted from the current program 
address. 


OPERAND 2: A 4-bit value in bits 12-15 of the instruction. This value 
specifies the position of the bit tested for on in the Condition register 
and may range from 0-15. 


EXAMPLE: SCTB TAG, 0 
Assume that TAG is six words behind this instruction. If bit 0 
(overflow bit) in the Condition register is on, the program will skip 


back six words (12 bytes) to TAG. If bit 0 is off, the next instruction 
in the program is executed. 


3-90 2999.00] 


FOR MEMOREX INTERNAL USE ONLY 


Sktp Uneondittonal - Forward 


FUNCTION: Skips forward a specified number of words. 

OPERAND: An 8-bit unsigned value in bits 8-15 of the instruction. 

This value specifies the number of words to skip and may range from 0-255. 
It is multiplied by 2 and added to the current program address. 


EXAMPLE: SF TAG. 


Skips unconditionally to TAG. 
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FOR MEMOREX INTERNAL USE ONLY 


Skip Uneondtttonal - Backward 


FUNCTION: Skips back a specified number of words. 

OPERAND: An 8-bit unsigned value in bits 8-15 of the instruction. 
This value specifies the number of words to skip and may range from 
0-255. It is multiplied by 2 and subtracted from the current program 
address. 

EXAMPLE: SB TAG 


Skips unconditionally to TAG. - 
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FOR MEMOREX INTERNAL USE ONLY 


COMPARE INSTRUCTIONS 


Mnemonic Code . Name 
CBYM Compare Byte Memory - Memory e 
CBY Compare Byte Memory - Register e 
CMPX Compare Characters e 
CMPD Compare Direct 
CMPI Compare Immediate 
CMPM Compare Memory - Memory 
CMP Compare Memory - Register 
CMPK . Compare Packed Decimal e 
CMPR . Compare Register - Register 
CMPT Compare Two-Word 
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FOR MEMOREX INTERNAL USE ONLY 


Compare Byte Memory — Memory e 


7 8 9 Tal 


CBYM @M, (Ry) ,@Mo(R.) — | — 


FUNCTION: Performs a magnitude-only comparison of one-byte fields in 
memory. . 


OPERAND 1: A one-byte field in memory. Addressing options to the base 
address M, include indexing (R,), indirect addressing (bit 8=1), ora 
combination of both. 


QPERAND 2: Same as operand | except use Mo, Ro, and bit 12=1. 


RESULTS: Neither operand is disturbed, but the Condition register is 
affected as follows: 


e Bits O and 4 are always cleared. 

e I!f operand | is greater than operand 2, bits | and 5 
are set and bits 2, 3, 6 and 7 are cleared. 

e if operand 1 is less than operand 2, bits 2 and 6 are 
set and bits 1, 3, 5 and 7 are cleared. 

e If operand 1 is equal to operand 2, bits 3 and 7 are set 
and bits 1, 2, 5 and 6 are cleared. 


EXAMPLE: CBYM @TAG(4) ,@HERE(2) 


Compares a one-byte operand at the address specified by @TAG(4) with 
another at the address specified by @HERE(2). If the operand at @TAG(4) 
is greater than the other operand, bit 1 of the Condition register is 
turned on; if less than the other, bit 2 of the Condition register is 
turned on; if they are equal bit 3 of the Condition register is turned 
on. (Only one of these bits in the Condition register will be turned 
on; the others remain off.) 
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Compare Byte Memory Register @ 
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FUNCTION: Performs a magnitude-only comparison of a one-byte field in 
memory and the low-order byte of a general register or a one-byte field 
in memory. 


QOPERAND 1: A one-byte field in memory. Addressing options to the 
base address M include indexing (Rj), indirect addressing (bit 8=1), 
or a combination of both. 


OPERAND 2: A one-byte field (bits 8-15) in a general register specified 
by Ro or a one-byte field in memory if indirect addressing is used, 
bit 12=1. 


RESULTS: Neither operand is disturbed, but the Condition register is 
affected as follows: 


@ Bits O and 4 are always cleared. 

@e If operand 1 is greater than operand 2, bits 1 and 5 are set 
and bits 2, 3, 6 and 7 are cleared. 

e@ If operand 1 is less than operand 2, bits 2 and 6 are set 
and bits 1, 3, 5 and 7 are cleared. 

e@ If operand 1 is equal to operand 2, bits 3 and 7 are set 
and bits 1, 2, 5 and 6 are cleared. 


EXAMPLE: CBY @TAG(4) ,6 


Compares a one-byte operand identified by @TAG(4) with the rightmost 
byte of register 6, and the Condition register is set accordingly. 
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Compare Characters e 


FUNCTION: Performs a magnitude-only comparison of two fields in 
memory. The field lengths may vary from 0-255 bytes. The comparison 
is byte-by-byte and proceeds from left to right. The operation con- 
tinues until either of the following occurs: the operands are found 
unequal or the greater of L, or Lo is exhausted. 


OPERAND 1: A field in memory. The field length, 0-255 bytes, is 
specified by the L, value in the instruction. Addressing options to 
the base address M, include only indexing (R,). 


OPERAND 2: A field in memory. The field length, 0-255 bytes, is 
specified by the Ly value in the instruction. Addressing options to 
the base address M, include only indexing (Ro). 


RESULTS: The following conditions may occur, depending on the values 
of Ly; and Lo. 


e If L; = Lg, the operands are compared byte-for-byte. 

e If Ly is less than Lg, the operands are compared unti! 
L} is exhausted, then blanks are compared to operand 2. 

e If L) fs greater than L2, the operands are compared until 
La is exhausted, then operand | is compared to blanks. 

e If ly 0 and Lg # 0, blanks are compared to operand 2. 

e If Lg = 0 and Ly = 0, no compare is performed. 


Neither operand is disturbed, but the Condition register is affected 
as follows: 


e Bit 0 (overflow) ts always cleared. 

e If operand 1 is greater than operand 2, bit 1 is set and 
bits 2 and 3 are cleared. 

e If operand 1 is less than operand 2, bit 2 is set and 
bits 1 and 3 are cleared. 

e I|f operand 2 is equal to operand 1, bit 3 is set and bits 
“| and 2 are cleared. 

e lf Ll=0 and L2=0, bits 1 and 2 are cleared and bit 3 is set. 


Note: CMPX is a word compare if Ly and Lz are both even and the 
beginning addresses are even. 
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EXAMPLE: CMPX TAG(200,1) ,HERE(200,2) 


A 200-byte field identified by TAG(200,1) is compared to a 200-byte 
field identified by HERE(200,2). Comparison proceeds byte-by-byte 
until inequality is determined or all bytes have been compared 

and found equal. The Condition register is set accordingly. 
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Compare Dtrect 
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FUNCTION: Performs a signed arithmetic comparison of a one-word 
immediate value* and a one-word field in a general register or in 
memory. 


OPERAND 1: A 16-bit immediate signed value in bits 16-31 of the 
instruction; the value may range from -32,768 to +32,767. 


*Indexing may be specified for operand 1. In this case, operand |] 
is derived by adding the | value and the general register contents 
specified by R;; no check for overflow or link is made during the 
indexing. 


OPERAND 2: A one-word field in the general register specified by Rg 
or in memory if indirect addressing is used, bit 12=1. 


RESULTS: Neither operand is disturbed, but the Condition register is 
affected as follows (bits 0-3 reflect the arithmetic results of the 
compare and bits 4-7 reflect the logical results of the compare): 


e Bits 0 and 4 are always cleared. 

e If operand 1 is equal to operand 2, bits 3 and 7 are set 
and bits 1, 2, 5 and 6 are cleared. 

e lf operand | is arithmetically greater than operand 2, 
bit 1 is set and bits 2 and 3 are cleared. 

e !f operand 1 is arithmetically less than operand 2, 
bit 2 is set and bits 1 and 3 are cleared. 

e If operand 1 is logically greater than operand 2, bit 5 
is set and bits 6 and 7 are cleared. 

e !f operand 1 is logically less than operand 2, bit 6 is set 
and bits 5 and 7 are cleared. 


For arithmetic results, 7FFF1¢ is the largest number and 80001¢ is the 
smallest number. 


For logical results, FFFF}¢ is the largest number and 000016 is the 
smallest number. 


EXAMPLE: CMPD ~-25000(5) ,@3 
The value -25,000 modified by the contents of register 5 is compared 


with the value at the location specified in register 3; the Condition 
register is set accordingly. 
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Compare Immediate 
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- FUNCTION: Performs a signed arithmetic comparison of a 4-bit immediate 
value and a one-word field in a general register or in memory. 


OPERAND 1: A 4-bit signed value in bits 8-11 of the instruction; the 
value may range from 0-15. The 4-bit value is compared with operand 2 
in bit positions 12-15 with bits 0-11 zeros. 


QOPERAND 2: A one-word field located in the general register specified 
by R or in memory if indirect addressing is used, bit 12=1. 


RESULTS: Operand 1 is not disturbed, but the Condition register is 


. affected as follows (bits 0-3 reflect the arithmetic results of the 


compare and bits 4-7 reflect the logical results): 


e Bits 0 and 4 are always cleared. 

e lf operand 1 is equal to operand 2, bits 3 and 7 are set 
and bits 1, 2, 5 and 6 are cleared. 

e If operand | is arithmetically greater than operand 2, 
bit 1 is set and bits 2 and 3 are cleared. 

e I!f operand 1 is arithmetically less than operand 2, bit 2 
is set and bits 1] and 3 are cleared. 

@ If operand | is logically greater than operand 2, bit 5 
is set and bits 6 and 7 are cleared. 

© If operand 1 ‘is logically less than operand 2, bit 6 
is set and bits 5 and 7 are cleared. 


For arithmetic results, TFFF 6 is the largest number and 800016 is the 
smallest number. . 


For logical results, FFFFi¢ is the largest number and 0000,¢ is the 
smallest number. 


EXAMPLE: CMPI 11,@6 


Compares the immediate value 11 to the value at the location specified 
in register 6 and sets the Condition register accordingly. 
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Compare Memory — Memory 
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FUNCTION: Performs a signed arithmetic comparison of two one-word 
fields in memory. 


OPERAND 1: A one-word field in memory. Addressing options to the base 
address M; include indexing (R}), indirect addressing (bit 8=1), or a 
combination of both. 


QPERAND 2: Same as operand | except use My, Ro, and bit 12=1. 


RESULTS: Neither operand is disturbed, but the Condition register is 
affected as follows (bits 0-3 reflect the arithmetic results of the 
compare and bits 4-7 reflect the logical results): 


e Bits 0 and 4 are always cleared. 

e If operand | is equal to operand 2, bits 3 and 7 are set 
and bits 1, 2, 5 and 6 are cleared. 

e@ If operand 1 is arithmetically greater than operand 2, 
bit 1 is set and bits 2 and 3 are cleared. 

e If operand 1 is arithmetically less than operand 2, 
bit 2 is set and bits 1] and 3 are cleared. 

@ If operand 1 is logically greater than operand 2, bit 5 

_ is set and bits 6 and 7 are cleared. 

e If operand 1 is logically less than operand 2, bit 6 is 
set and bits 5 and 7 are cleared. 


For arithmetic results, 7FFFI6 is the largest number and 800016 is the 
smallest number. 


For logical results, FFFFy¢ is the largest number and 0000)¢ is the 
smallest number. 


EXAMPLE: CMPM § @HERE(4) ,@TAG(6) 
A 16-bit value at the address specified by @HERE(4) is compared to a 


16-bit value at the address identified by @TAG(6); the Condition 
register is set accordingly. 
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Compare Memory — Register 
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FUNCTION: Performs a signed arithmetic comparison of a one-word field 
in'memory. and a one-word field in a general register or in memory. 


OPERAND 1: A one-word field in memory. Addressing options to the base 
address M include Indexing (Rj ), indirect addressing (bit 8= 1), ora 
combination of both. . 


OPERAND 2: A one-word field in the: general register specified Py Ro or 
tn memory if indirect addressing is used, bit 12=1. 


RESULTS: Neither operand is disturbed, but the Condition register is 
affected as follows (bits 0-3 reflect the arithmetic results of the 
compare and bits 4-7 reflect the logical results of the compare): 


e@ Bits 0 and 4 are always cleared. : 

e lf operand 1 is equal to operand 2, bits 3 and 7 are set 

- and bits 1, 2, 5 and 6 are cleared. : 

e (If operand 1 is arithmetically greater than operand 2, 
bit 1 is set and bits 2 and 3 are cleared. 

@ If operand 1.is arithmetically less an operand 2, bit 2 

- 1s set and bits 1 and 3 are cleared. 

e@ If operand'1] is logically greater ee operand 2, bit 5 
is set and bits 6 and 7 are cleared. 

e If operand 1 is logically less than sparand 2; bit 6 

~ —s set and bits 5 and 7 are cleared. 


For arithmetic results, 7FFFi¢ is the largest number and 800016 is the 
smallest number. 


For logical Pasties, eCPEIG is the largest number and aa is the 
smal test ‘number. ; . 


EXAMPLE: CMP @TAG(5) ,@6 | 
A 16-bit field at the address identified by @TAG(5) is compared to a 


‘16-bit field at the address specified in register 6; the Condition 
register is set accordingly. 


FOR MEMOREX INTERNAL USE ONLY 


Compare Packed Decimal e 
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FUNCTION: Performs a comparison of packed decimal fields in memory; 
the signs are compared first, then the comparison proceeds digit-by- 
digit, left to right. The field lengths may vary from 0-255 bytes. 
The operation continues until either of the following occurs: the 
“operands are found unequal or the greater of L; or Ly is exhausted. 


OPERAND 1: A packed decimal field in memory. The field length, 0-255 
bytes, is specified by the Lj value in the instruction. Addressing 
options to the base address M, include only indexing (Ry). 


OPERAND 2: A packed decimal field in memory. The field length, 0-255 
bytes, is specified by the Ly value in the instruction. Addressing 
options to the base address Mo include only indexing (Ro). 


RESULTS: The following conditions may occur, depending on the values of 
Ly and Lo: 


e If Ly = Lo, the operands are compared digit-by-digit. 

e lf L, is fess than Ly», the operands are compared until 
Ly} is exhausted, then zeros are compared to operand 2. 

e If L, is greater than Ly, the operands are compared until Lo 
is exhausted, then zeros are compared to operand 1. 

e If L} = 0 and Lg = 0, bit 3 of the Condition register is set 
and bits | and 2 are cleared. 


Neither operand is disturbed, but the Condition register is affected 
as follows: 


e Bit 0 is always cleared. 

e If operand 1 is greater than operand 2, bit 1 is set and 
bits 2 and 3 are cleared. 

e If operand 1 is less than operand 2, bit 2 is set and bits 
] and 3 are cleared. 

e If operand 1 is equal to operand 2, bit 3 is set and bits 
l and 2 are cleared. 
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EXAMPLE: CMPK TAG(90,1) ,HERE(101, 3) | 


Two packed decimal fields are compared; the Condition register is 

set accordingly. In this example, the field represented by TAG(90,1) 
is shorter than the other; therefore, bytes 91 through 101 of the 
larger field, HERE(101,3), will be compared to zeros if an inequality 
determination cannot be made before exhaustion of the smaller field. 


Since the signs are checked first, an inequality decision could be 
made immediately if the signs are different. 
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Compare Register — Regtster 
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FUNCTION: Performs a signed arithmetic comparison of two one-word 
fields; either field may be in a register or in memory. 


QOPERAND 1: A one-word field located in the general register specified 
by Ry or in memory if indirect addressing is used, bit 8=1. 


QOPERAND 2: Same as operand | except use Ry and bit 12=1. 


RESULTS: Neither operand is disturbed, but the Condition register is 
affected as follows (bits 0-3 reflect the arithmetic results of the 
compare, and bits 4-7 reflect the logical results): 


e Bits 0 and 4 are always cleared. 

e If operand 1 is equal to operand 2, bits 3 and 7 are set 
and bits 1, 2, 5 and 6 are cleared. 

@ If operand | is arithmetically greater than operand 2, 
bit 1 is set and bits 2 and 3 are cleared. 

e If operand 1 is arithmetically less than operand 2, 

_ bit 2 is set and bits | and 3 are cleared. 

@ If operand 1 is logically greater than operand 2, 
bit 5 is set and bits 6 and 7 are cleared. 

e If operand 1 is logically less than operand 2, bit 6 
is set and bits 5 and 7 are cleared. 


For arithmetic results, TFFF 16 is the largest number and 80001¢ is the 
smallest number. 


For logical results, FFFFyg¢ is the largest number and 0000)¢ is the 
smallest number. 


EXAMPLE: CMPR @7,@5 
A 16-bit field at a location specified in register 7 is compared to a 


16-bit field at a location specified in register 5; the Condition 
register is set accordingly. 
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Compare Two-Word 
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FUNCTION: . Performs a signed arithmetic comparison of a two-word field 
in memory and a two-word field in two general registers or in memory. 


OPERAND 1: A two-word field in memory. Addressing options to the base 
address M include indexing (R,), indirect addressing (bit 8=1), or a 
combination of both. The effective address points to the most significant 
bits of the two-word field. 


QPERAND 2: A two-word field in two general registers (the most 
significant bits in the register specified in Rg and the least 
significant bits in the register specified by R2 + 1) or in memory 
if indirect addressing is used, bit 12=1. 


RESULTS: Neither operand is disturbed, but the Condition register is 
affected as follows (bits 0-3 reflect the arithmetic results of the 
compare and bits 4-7 reflect the logical results): 


e@ Bits 0 and 4 are always cleared. 

e !f operand 1 is equal to operand B, bits 3 and 7 are set 
and bits 1, 2, 5 and 6 are cleared. 

e@ If operand 2 is arithmetically greater than operand 2, bit 1} 
is set and bits 2 and 3 are cleared. 

e If operand 1] is arithmetically less than operand 2, bit 2 
is set and bits 1 and 3 are cleared. 

e If operand 1 ts logically greater than operand 2, bit 5 
is set and bits 6 and 7 are cleared. 

@ If operand 1 is logically less than operand 2, bit 6 
is set and bits 5 and 7 are cleared. 


For arithmetic results, 7FFFi¢ is the largest number and 800016 is the 
smallest number. 


For logical results, FFFFy¢ is the largest number and 0000;¢ is the 
smallest number. 


EXAMPLE: CMPT @TAG (4) ,@1 
A 32-bit field at the address identified by @TAG(4) is compared to a 


32-bit field at the address specified in register 1; the Condition 
register is set accordingly. 


FOR MEMOREX INTERNAL USE ONLY 
DATA CONVERSION INSTRUCTIONS 


Mnemonic Code Name 
CVB Convert to Binary e@ 
CVBT Convert to Binary Two-Word e 
CVD Convert to Decimal e 
CVDT Convert to Decimal Two-Word e 
EDTX Packed Decimal/Alpha Edit e 
PAKX Pack e 
TRNX Translate e@ 
UNPX Unpack e 
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Convert to Binary e 


CVB @M(R7) ,R»o 


FUNCTION: Converts a 3-byte packed decimal field in memory to a 2-byte 
binary field in a general register. 


Extended Function Code: Bit 12 serves as an extension to the basic 
function code and is 0 for this instruction. 


OPERAND 1: A 3-byte packed decimal field in memory. Addressing options 
to the base address M include indexing (Ry), indirect addressing . 

(bit 8=1), or a combination of both. The packed decimal field may hold 
five digits and a sign. The effective address points to the most 
significant byte of the field 


OPERAND 2: The resultant 2-byte signed binary value in the general 
register specified by Rg. The binary value has 15 bits and a sign bit. 


RESULTS: The resulting value resides at the operand 2 location. 
e Bit 0 (overflow) is set if results are greater than 
+32,767 or less than -32,767. (Note: -32,768 is converted 


correctly but the overflow bit is set.) 
e Bits 1-3 unchanged. 


EXAMPLE: CVB ®@TAG(4) ,6 
@TAG(4) yields the address of a 3-byte packed decimal field (five 


digits plus sign) which is converted to a 16-bit (15 bits plus sign) 
binary value and loaded into register 6. | 
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Convert to Binary Two-Word e 
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FUNCTION: Converts a 6-byte packed decimal field in memory to a 4- 
byte binary field in two general registers. 


Extended Function Code: Bit 12 serves as an extension to the basic 
function code and is | for this instruction. 


OPERAND 1: A 6-byte packed decimal field in memory. Addressing 
options to the base address M include indexing (Ry), indirect 
addressing (bit 8=1), or a combination of both. The packed decimal 
fleld may hold 11 digits and a sign. The effective address points to 
the most significant byte of the field. 


OPERAND 2: The resultant 4-byte signed binary value located in two 
general registers (the most significant bits in the register specified 
by Rj and the least significant bits in the register Ro+1). (Note: 

If register 7 is specified by Ro, the most significant bits are placed 
in register 7 and the least significant bits in register 0.) The 
binary value has 31 bits of magnitude and a sign bit. 


RESULTS: , The resulting value resides at the operand 2 location. 
e Bit 0 (overflow) is set if results are greater than +2312] 
or less than -23!-1, (Note: -231 is converted correctly 


but the overflow bit is set.) 
e Bits 1-3 are unchanged. 


EXAMPLE: CVBT @TAG(3),7 
@TAG(3) yields the address of a 6-byte packed decimal field (11 


digits plus sign) which is converted to a 32-bit (include sign) binary 
value and loaded into register 7. 
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Convert to Decimal e 


CVD @M(R}),Ro 


FUNCTION: Converts a 2-byte binary field in a general register to a 3- 
byte packed decimal field in memory. 


Extended Function Code: Bit 12 serves as an extension to the basic 
function code and is 0 for this instruction. 


QPERAND 1: The resultant 3-byte packed decimal field in memory which 
can hold as many as five digits and a sign. Addressing options to the 
base address M Include Indexing (Ry), indirect addressing (bit 8=1), 
or a combination of both. The effective address points to the most 
significant byte of the field. 


OPERAND 2: A 2-byte signed binary value in the general register 
specified by Rg. The binary value has 15 bits and a sign bit. 


RESULTS: The resulting value resides at the operand 1 location. 


EXAMPLE: CVD @TAG(1),2 


Register 2 contains a 16-bit binary value which is converted to a 
aca packed decimal field and stored at the location specified by 
@TAG(1). 
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Convert to Dectmal Two-Word e 


7 8 9 11 12 13 15 


0 
cvOT QM ORI) A peda 


FUNCTION: Converts a 4-byte signed binary field located in two 
general registers to a 6-byte packed decimal field located in memory. 


Extended Function Code: Bit 12 serves as an extension to the basic 
function code and is | for the CVDT instruction. 


OPERAND 1: The resultant 6-byte packed decimal field located in 
memory. Addressing options to the base address M include indexing 
(Rj), indirect addressing (bit 8=1), or a combination of both. The 
packed decimal field may hold 11 digits and a sign. The effective 
address points to the most significant byte of the field. 


OPERAND 2: A 4-byte signed binary value located in two general 
registers. The most significant bits are in the register specified 
by Rg and the least significant bits in register Ro+l. The binary 
value has 31 bits and a sign bit. (Note: If register 7 is specified 
by Rg, the most significant bits are in register 7 and the least 
significant bits are in register 0.) 


RESULTS: The resulting value resides at the operand | location. 


EXAMPLE: CVDT ®@TAG(4),3 
Registers 3 and 4 contain a 32-bit binary value which is converted 


to 6-byte packed decimal (11 digits plus sign) and stored at the 
location identified by @TAG(4). 
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Packed Decimal/Alpha Edit e 
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FUNCTION: This instruction moves the contents of a source field to a 
result field with editing symbols inserted according to an edit mask. 
The first-byte address of the mask field must be set in general 
register 1 prior to execution of the edit instruction. A more complete 
description of the functions performed and details of the edit mask 


OPERAND 1: The field in memory to be edited. It must be a packed 
decimal field for numeric editing; for alpha editing it must be an 
EBCDIC field. For numeric editing, the number of digits in the source 
field is specified in L}; for alpha editing, no length is specified. 
Addressing options to the base address include only indexing (Ry). 


OPERAND 2: The field in memory that will hold the edited results. 

[It will always be an EBCDIC field. For numeric editing, the length in 
bytes of the result field is specified in Lg. For alpha editing, L2 
must be zero. Addressing options to the base address M2 include only 
indexing (Ro). 


RESULTS: An EBCDIC field at the operand 2 location. Results depend 
on the type of editing and on the contents of the edit mask. 
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EXAMPLE: EDTX  TAG(5),HERE(6) 


No length is specified because, in the example, the field to be 
edited is assumed to be an alpha field; as such, both fields are 
EBCDIC. 


The location TAG(5) contains the alpha field to be edited, and the 


field at the address HERE(6) receives the editing symbols generated 
during the edit. 
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DETAILED DESCRIPTION OF EDIT 
The EDTX instruction performs both numeric editing and alpha editing. 


The source field is moved to the result field with editing symbols 
inserted according to the edit mask. The result field is always an 
EBCDIC field. The source field must be a packed decimal field when 
numeric editing is requested (Lo#0). The source field must be an 
EBCDIC field when alpha editing is requested (Lo= 0). 


The editing function iF terminated as dictated by the edit mask. The 
length specifications (L] and Lz) are used when numeric editing is 
requested to unpack the source Tieng UNPX) before actual editing 
begins. 


Upon return from a numeric edit, general register 1 contains the byte 
address of the last nonsignificant (FO value) character. This address 
is used to store the float character if desired. If there is no signif- 
icant character (source field has zero value), general register 1 will 
be set to zero. This register will always be set to zero following an 
alpha edit. 


The Condition register is set as follows when numeric editing is 
requested. 


e Bit 3 set —All source digits were zero 
e Bit 2 set — The source field: was negative 
@e Bit 1 set — The source field was positive 


The Condition register is not used or modified when alpha editing is 
requested. 


Edit Mask: Editing is accomplished by means of an edit control tech- 
nique. The mask field, which is referenced (but not changed) by 

the EDTX instruction, is used to control data movement from the source 
field to the result field. The mask field is made up of a string of 

one character (two hexadecimal digits) edit operators and EBCDIC insert 
characters. The edit operators are basically. control functions directing 
the edit microcode rather than the traditional mask used by the edit 
microcode to drive the editing function. 


To facilitate a clear understanding of the editing process, the follow- 
ing microcode indicators are defined. These indicators are internal 

to the microcode and not directly accessible by the user. They are 
initialized by the microcode as defined below. The edit mask operators 
direct the resetting and use of these indicators. 


There are two microcode indicators and one 8-bit value field which the 
edit microcode requires to effect the execution of the EDTX instruction. 
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SD - Significance Digit Indicator 
Initially SD is set to zero and is set to one when 
significance is detected (by edit operator or by 
occurrence of a non-zero digit in the source). 


SG - Sign tndicator 


The SG indicator is set according to the Condition 
register after the source has been unpacked. 


EQ = Bit 3 set - source is equal to zero 
LT = Bit 2 set - source is negative 
GT = Bit | set - source is positive 

4 

Fl - Fill Character - 8-bit EBCDIC 


Initially set with EBCDIC space (40 hex). The fill 
character may be specified via the Set Fill edit 
operator to any EBCDIC value. 

The edit operators within the mask field have the following format. 


0 7 
: 


The first (zone) digit of each edit operator character is the variant 
specifier, V. The second (numeric) digit is the function specifier, F. 
When used, V specifies either repeat count of the function F or sub- 
control information. Otherwise V is ignored. 
The edit operators divide into three functional categories. 

e Data Transfer 

e Data Insert 


e Control 


Data Transfer operators specify conditional and unconditional transfer 
of data from the source field to the result field. 


Data Insert operators specify conditional and unconditional insertion 
of characters into the result field where there is no dependency or 
reference to the source field. 


Control operators function as explicit edit performance controls where 
there is no reference directly to the source or result fields. 
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The function code F specifies the operation to be performed. These 
codes have a numerical 4-bit hexadecimal assignment. Following is a.’ 
list of the edit operators with the F code divided into categories. 


CATEGORY OPERATOR F=HEX  F-BINARY OPERATOR DESCRIPTION 
Data Move character 
Transfer Move character suppress 
Insert character 
Data 
Insert character suppress 


Insert 
Insert sign 


Terminate edit 


Control Set significance (SD) 


Set fill (FI) 


The IC, ICS, and SFI operators require one insert character following 
the edit operator. The ISG operator requires either one or two insert 
characters following the ISG edit operator. I!n all cases the insert 
characters are bypassed automatically by the microcode to obtain the 
next edit operator. 


Numeric Editing: The edit operators function as follows during a 
numeric edit. 
MC - Move Character F = 8 

e If SD equals zero, perform the $SD operation (absolute). 


@ Move a character from the unpacked source field to the result 
field. 


e V specifies a repeat count (0-15). 
MCS - Move Character Suppress F = 9 
e If SD equals one, perform the MC operation. 
e If SD equals zero and the next source character equals 


zero, move the fill character from FI to the result 
field. 
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e If SD equals zero and the next source character is non- 
zero, perform the MC operation (SD gets set equal to one 
by MC). 


@ V specifies a repeat count (0-15). 
IC - Insert Character F = 4 


@ Move the character following this edit operator to the 
result field. 


e V specifies a repeat count (0-15). The same character 
will be inserted V+] number of times. 


ICS - Insert Character Suppress F = 5 
e If SD equals one, perform the IC operation. 


e If SD equals zero, move the fill character from Fl to the 
result field. 


e V specifies a repeat count (0-15). The same character 
(fill character or insert character) will be inserted 
V+1 number of times. 


ISG - Insert Sign F = 7 


e If SG = LT (negative source) and 
V=0, move the character following this edit operator 
to the result field; 
V=1, move the character following the edit operator to 
the result field; 
V=2, move the two characters following this edit operator 
to the result field. 


e If SG = EQ or GT (positive source) and 
V=0, move a + (4E hex) to the result field; 
V=1, move a space (40 hex) to the result field; 
V=2, move two spaces to the result field. 


e V is a sub-control function specifying the type of sign 
inserted. 


TE - Terminate Edit F = 0 
e Immediately terminates the EDTX instruction. 
e The Condition register has been set to EQ, GT, or LT. 
e General register 1 is set to the address - | of the first 
significant character within the source. It is set to zero 


if there was no significance found. 


e V is not used. 
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SSD - Set Significance F = 2 


V is a sub-control function specifying whether absolute or con- 
ditional set significance is requested. 


lf V= 


lf Ve= 


1 - Absolute Set Significance 


l 


) Set SD equal to one. 


2) Set current result field address - 1 in general register 


l as float address. 


0 - Conditional Set Significance 


1) 
2) If SD equals zero and SG=EQ, this is a no operation. 
3) If SD equals zero and SG=GT or LT (source non-zero), 


If SD equals one, this is a no operation. 


perform the absolute set significance. 


SFI - Set Fill Character F = 6 


@e Set Fl with the character following this edit operator 
in the mask field. 


e Vis not used. 


Unusual Conditions in Numeric Editing: The following hexadecimal 
values are not legal numeric editing functions. If encountered, the 


following 
e uF 
e UF 
e@ 6F 
e UF 
e@ F 
1) 

2) 

3) 

e mF 
1) 

2) 

3) 

4) 


results will be obtained. 


1 - A normal Terminate Edit (TE) will be executed. 
3 - A normal Set Significance (SSD) will be executed. 
C - A normal Move Character (MC) will be executed. 


D - A normal Move Character Suppress (MCS) will be 
executed. 


= AoreE 


If SD equals one, move source character to result field. 
If SD equals zero, perform the absolute Set Significance 
operation, skip the next source character. 

V is ignored. 


Bor F 

If SD equals one, move the source character to the 
result field. 

If SD equals zero and the source character is non- 
zero, perform the absolute Set Significance; skip the 
next source character. 

If SD equals zero and the source character is zero, 
move the FI value to the result field. 

V is ignored. 


Since the source field is unpacked into the result field, right 
justified, the length specification Lo must be greater than Lj. 


If Ly is equal to or less than L], the source character could 
possibly be replaced by editing insert characters and unpredictable 
results may be obtained. 
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Alpha Editing: Alpha editing is performed when Lo = 0. The edit 
operators generally used to effect alpha editing are TE, IC, and MC. 


The SSD, SFL, and ICS will function but are not generally of use in 
the alpha editing. Following is a description of the editing opera- 
tions. 
MC - Move Character F = 8 
@ Move a character from the source field to the result field. 
@ V is a repeat count (0-15). 
@ SD is not set. 
IC - Insert Character F = 4 
@ Same as for numeric editing. 
ICS - Insert Character Suppress F = 5 
@ Same as for numeric editing. 


TE - Terminate Edit F = 0 


@® Immediately terminate the edit and return control to 
the caller. 


SSD - Set Significance F = 2 
® If V= 1 and SD = 0, set SD= 1. 


@ The address of the last byte moved or inserted into the 
result is placed in R,. 


e If V=0 or SD = 1, no operation. 
SFi - Set Fill F = 6 
@ Same as for numeric editing. 
Unusual Conditions in Alpha Editing: The following hexadecimal values 


are not legal alpha editing functions. {f encountered, the following 
results will be obtained. 


e F = 1 - A normal Terminate Edit (TE) will be executed. 
@ F = 3 - A normal Set Significance (SSD) will be executed. 
e F = 7 - The Insert Sign has no meaning in that the Condition 


register is not set in alpha editing and the SG does 
not contain a meaningful value. 


e@ F = 9, C, or D - Treated as a normal Move Character (MC). 


e F =A, B, E, or F - One character is moved from the source 
field to the result field. V is ignored. 
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The Condition register is not used or modified by alpha editing. 
General register 1 is set to zero upon return from alpha editing. 
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Pack e@ 


1112 13 


PAKX Mz (Ly4Rz) »Mp (Lop) 


FUNCTION: Converts a zoned decimal field to a packed decimal field. 
Both fields must be in memory; the field lengths may vary from 0-255. 
Packing proceeds from right to left until the greater of the field 
lengths is exhausted. 


OPERAND 1: The zoned decimal field; the length of the field, in 
bytes, is specified by the L; value in the instruction. Addressing 
options to the base address M; include only indexing (Ry). 


OPERAND 2: The resultant packed decimal field; the length of the 
field, in bytes, is specified by the Ly value in the instruction. 
Addressing options to the base address Ma include only indexing (R95). 


RESULTS: The resulting field resides at the operand 2 location. 
Condition register settings are: 


1. Overflow (bit 0) is always cleared. 

2. Invalid (bit 4) is set if an invalid decimal digit (not 0-9) 
occurs in operand |] or if the sign field is not A-F; bits 
1-3 are cleared. However, packing continues until the length 


Ly is exhausted. 


3. No significance in the result (packed field) sets bit 3, 
clears 1, 2 and 4. 


4, Significance and a sign of F, A, C or E sets bit 1 and clears 
2-4, 


5. Significance and a sign of B or D sets bit 2 and clears 1, 3 
and 4, 


EXAMPLE: PAKX TAG(239,3),HERE(120,4) 
The unpacked (zoned) 239-byte field identified by TAG(239,3) is 


packed (4-bit zone codes removed) and then stored at the address 
identified by HERE(120,4). 
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Translate e@ 


TRNX My (Rq) »Mp(Lo,Ro) 


FUNCTION: Translates, byte-by-byte, the contents of a memory field by 
a table, replacing the source values with the translated table values. 
The table is in memory at the address specified in general register 1. 
The table has an assumed length of 256 bytes. 


OPERAND 1: The field in memory to be translated. Addressing options 
to the base address M; include only indexing (Ro). 


OPERAND 2: The field in memory which holds the translated values. 
Addressing options to the base address M2 include only indexing 
(Ro). The field length, 1-256 bytes, is specified by the L2 value. 


RESULTS: The translated results reside at the operand 2 location. 
EXAMPLE: TRNX TAG(3),HERE(255, 2) 


The 256 bytes identified by TAG(3) are moved byte-by-byte to a 

field identified by HERE(256,2). Each byte value extracted from the 
TAG(3) field is used as an index to the translate table (address 
specified in register 1). The byte stored in operand 2 is the translate 
value at the indexed byte. 


Note: The length specified in assembler language is the actual field 


length, but the length in the machine instruction is one less than 
the actual length. 
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Unpack @ 


UNPX M7 (Ly,Ry) 4Mo(Lo,R,) 


FUNCTION: Converts a packed decimal field to a zoned decimal field. 
Both fields must be in memory; the field lengths may vary from 0-255. 
Unpacking proceeds from right to left. The zoned decimal field must 
contain at least as many bytes as there are significant digits in the 
packed decimal field. 


OPERAND 1: The packed decimal field; the length of the field, 0-255 
bytes, is specified by the L, value in the instruction. Addressing 
options to the base address Mj, include only indexing (Rj). 


OPERAND 2: The resultant zoned decimal field; the length of the field, 
0-255 bytes, is specified in the Lo field of the instruction. Address- 
ing options to the base address Mg include only indexing (Ro). 


RESULTS: The resulting field resides at the operand 2 location. 
Condition register settings: are: 


1. Bit 0 and bit 4 (invalid) are always cleared. 


2. If no significance results bit 3 is set, bit |] and 2 are 
cleared. 


3. If significance results and the sign is F, A, C, E, 0, 2, 4, 
6, 7, or 8, bit 1 is set and bits 2 and 3 are cleared. 


4, If significance results and the sign is B, D, 1, 3, 5, or 9, 
bit 2 is set and bits 1] and 3 are cleared. ; 


EXAMPLE: UNPX TAG (120, 4) , HERE (239, 2) 
Converts the 120-byte packed decimal field identified by TAG(120,4) 


to unpacked decimal, and stores them at the field identified by 
HERE (239, 2). 
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DATA TRANSFER INSTRUCTIONS 


Mnemonic Code Name 
CLDR Condition Register Load 
CSTR Condition Register Store 
INVD Inverse Move Direct 
INVI Inverse Move Immediate 
INVM Inverse Move Memory - Memory 
INV Inverse Move Memory - Register 
INVR Inverse Move Register - Register 
LODB Load Byte e 
LODD Load Direct 
LOD! Load Immediate 
LOD Load Memory - Register 
LODT Load Two-Word 
MOVB Move Byte e 
MOVX Move Characters e 
MOVL Move Long e 
MOVM Move Memory - Memory 
MOVR Move Register - Register 
PSTR Program Address Store 
STOB Store Byte e 
STO Store Memory - Register 
STOT Store Two-Word 
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Condition Register Load 


CLDR~ @R 


FUNCTION: Transfers the contents of a one-word field in a register or 
in memory to the Condition register. (Note: If any of the bits 12- 

15 in the field being transferred are on, false status conditions 

(such as a bounds error) may be transmitted to the executive program 
when the Condition register is loaded. This does not apply if the 
field being transferred was originally generated by a CSTR instruction.) 


OPERAND: A one-word value in the general register specified by R or in 
memory if indirect addressing is used, bit 8=]. 


EXAMPLE: CLDR  @5 


A 16-bit field located at the address specified in register 5 is 
transferred to the Condition register. 
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Condttion Register Store 


0 7 8 11 12 13 15 


CSTR OR 
FUNCTION: Transfers the contents of the Condition register to a one- 
word field in a register or in memory. 


OPERAND: A one-word value in the general register specified by R 
or in memory if indirect addressing is used, bit 12=1. 


EXAMPLE: CSTR @6 


The contents of the Condition register are transferred to the location 
specified in register 6. 
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Inverse Move Dtrect 


0 9 11 12 13 15 


INVD —1(Ry),@Ry 


FUNCTION: Transfers the one's complement of a one-word immediate 
value* to a one-word field in a general register or in memory. 


OPERAND 1: A 16-bit immediate value in bits 16-31 of the instruction; 
the value may range from 0-65,535. 


*Indexing may be specified for operand 1. In this case, operand | 
is derived by adding the | value and the general register contents 


specified by R;; no check for overflow or link is made during the 
indexing. 


OPERAND 2: A one-word field in the general register specified by 
Rg or in memory if indirect addressing is used, bit 12=1. 


RESULTS: The resulting value resides at the operand 2 location. 


EXAMPLE: INVD 60150(4),@7 
The one's complement of the value formed by adding 60,150 to the 


contents of register 4 is transferred to the location specified in 
register 7. 
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Inverse Move Immedtate 


0 7 8 11 12 13 15 


FUNCTION: Transfers the one's complement of a 4-bit immediate value 
to bits 12-15 of a one-word field in a general register or in memory. 
Bits O-1l1 of the one-word field are always set to ones. 


OPERAND 1: A 4-bit unsigned value in bits 8-11 of the instruction; 
the value may range from 0-15. 


QOPERAND 2: A one-word field in the general register specified by R 
or in memory if indirect addressing is used, bit 12=]. 


RESULTS: The resulting value resides in bits 12-15 of operand 2. 


EXAMPLE: INVI 11,@3 


The one's complement of 11 is transferred to bits 12-15 of a 16-bit 
field located at the address specified in register 3. Bits O-11 in 
the 16-bit field are turned on; the result field appears as follows: 
TVTV717117110100. 
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Inverse Move Memory — Memory 


INVM  @M, (R,) ,@M, (R,) 


FUNCTION: Transfers the one's complement of a one-word field in 
memory to another one-word field in memory. 


OPERAND 1: The field to be transferred; a one-word field in memory. 
Addressing options to the base address M; include indexing (Ry), 
indirect addressing (bit 8=1), or a combination of both. 


OPERAND 2: Same as operand | except use Mo, Ro, and bit 12=1. 


RESULTS: The resulting value resides at the operand 2 location. 


EXAMPLE: INVM @TAG(3),@HERE (2) 
The one's complement of a 16-bit field located at an address identified 


by @TAG(3) is transferred to the field at the address identified by 
@HERE(2). 
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Inverse Move Memory — Register 


0 7 8 9 11 12 13 15 


INV = =@M(R}) ,@Ro 


FUNCTION: Transfers the one's complement of a one-word field in 
memory to a one-word field in a general register or in memory. 


OPERAND 1: The field to be transferred; a one-word field in memory. 
Addressing options to the base address M include indexing (Rj), in- 
direct addressing (bit 8=1), or a combination of both. 

OPERAND 2: The receiving field; a one-word field in the general register 
specified by Ro or in memory if indirect addressing is used, bit 

12=1. 


RESULTS: The resulting value resides at the operand 2 location. 


EXAMPLE: INV @TAG(4),@1 


The 16-bit field identified by @TAG(4) is transferred in one's 
complement format to the location specified in register 1. 
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Inverse Move Register — Register 


0 7 8 9 11 12 13 15 


IWVR Ry OR, Pfam fd re 


FUNCTION: Transfers the one's complement of a one-word field to 
another one-word field; either field may be in a register or in 
memory. . 

OPERAND 1: The value to be transferred; a one-word field located in 
the general register specified by Ry or in memory if indirect 
addressing is used, bit 8=1. 


OPERAND 2: A one-word field located in the general register specified 
by Ro or in memory if indirect addressing is used, bit 12=1. 


RESULTS: The resulting value resides at the operand 2 location. 


EXAMPLE: INVR Iy2 


The contents of register 1 are converted to one's complement format 
and stored in register 2. 
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Load Byte e 


7 8 9 - 11 12 13 15 


LODB @M(R1),@R> 


FUNCTION: Transfers a one-byte field in memory to bits 8-15 of a 
one-word field in a general register or to one-byte in memory. 


QPERAND 1: The value to be transferred; a one-byte field in memory. 
Addressing options to the base address M include indexing (R}), 
indirect addressing (bit 8=1), or a combination of both. 


QPERAND 2: A one-word field in the general register specified by Ro 
or in memory if indirect addressing is used, bit 12=]. If the field 
is in a general register, the byte is placed in bits 8-15 and bits 0-7 
are zeroed out. © 


RESULTS: The resulting byte resides at the operand 2 location. 


EXAMPLE: LODB  @TAG(3),6 
@TAG(3) yields the address of a one-byte field in memory which is 


transferred to bits 8-15 of register 6. (If @6 had been specified, 
bits 0-7 of a memory word would receive the byte.) 
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Load Direct 


0 7 8 9 11 12 13 15 


LODD 1(R}),@Ry wm fo di A Ay 


FUNCTION: Transfers contents of a one-word immediate value* to a 
one-word field in a general register or in memory. 


QPERAND 1: A 16-bit immediate value in bits 16-31 of the instruction; 
the value may range from 0-65,535. . 
*I|ndexing may be specified for operand 1. In this case, operand | 

is derived by adding the | value and the index register contents 
specified by R;}; no check for overflow or link is made during the 
indexing. 


QPERAND 2: A one-word field in the general register specified by Ro 
or in memory if indirect addressing is used, bit 12=1. 


RESULTS: The resulting value resides at the operand 2 location. 


EXAMPLE: LODD  40000(4),@5 
The immediate value 40,000 is added to the contents of register 4, 


and the resulting value is transferred to the address specified in 
register 5. 
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Load Immediate 


0 | 1112 13 


Loo! ek ee ee 


FUNCTION: Transfers a 4-bit immediate value to bits 12-15 of a one- 
word field in a general register or in memory. 


OPERAND 1: A 4-bit unsigned value located in bits 8-1] of the instruc- 
tion; the value may range from 0-15. 


OPERAND 2: . A one-word field located in the general register specified 
by R or in memory if indirect addressing is used, bit 12=]. 


RESULTS: The resulting value resides at the operand 2 location. The 


value from operand | is placed in bits 12-15 of operand 2; bits 0-11 
of operand 2 are always zeroed out. 


EXAMPLE: LODI 14,03. 
The immediate value 14 is written in memory at the location specified 


in register 3. The result in memory appears as follows: 
0000000000001110. 
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Load Memory — Register 


0 7 8 9 11 12 13 15 


LOD @M(R1) ,@R> 


FUNCTION: Transfers the contents of a one-word field in memory to a 
one-word field in a general register or in memory. 


OPERAND 1: A one-word field in memory. Addressing options to the base 
address M include indexing (Rj), indirect addressing (bit 8=1), or a 
combination of both. 


OPERAND 2: A one-word field in the general register specified by Ro 
or in memory if indirect addressing is used, bit 12=]. 


RESULTS: The resulting value resides at the operand 2 location. 


EXAMPLE: LOD @TAG(4),@5 


@TAG(4) yields the address in memory of a 16-bit value which is 
transferred to another location specified by the address in register 5. 
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Load Two-Word 


LODT  @M(R}),@Ro 


FUNCTION: Transfers the contents of a two-word field in memory to 
a two-word field in a general register or in memory. 


OPERAND 1: A two-word field in memory. Addressing options to the base 
address M include indexing (R}), indirect addressing (bit 8=1), or a 
combination of both. The effective address points to the most significant 
byte of the field. 


OPERAND 2: A two-word field in two general registers (the most sig- 
nificant bit in the register specified by R2 and the least significant 
bit in register Ro+1) or in memory If indirect addressing is specified, 
bit 12=1. The effective address points to the most significant bits of 
the two-word field. 


RESULTS: The resulting values reside at the operand 2 location. 


EXAMPLE: LODT @HERE(7),5 


The 32-bit field identified by @HERE(7) is loaded into registers 5 and 6. 
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Move Byte e 


0 7 8 9 11 12 13 15 


MOVB @M) (Ry ),@M, (Ro) 


FUNCTION: Transfers a one-byte field in memory to another one-byte 
field in memory. 


OPERAND 1: The byte transferred; a one-byte field in memory. Addressing 
options to the base address M, include indexing (Ry), indirect addressing 
(bit 8=1), or a combination of both. 


OPERAND 2: The receiving field; a one-byte field in memory. Address- 
ing is the same as for operand I except use Mog, Ro, and bit 12=1. 


RESULTS: The resulting value resides at the operand 2 location. 


EXAMPLE: MOVB @TAG(1),@HERE (4) 


A byte at the address identified by @TAG(1) is moved to the location 
identified by @HERE(4). 
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Move Characters e 


MOVX My (Ly Ry) My (Ly »Ro) 


FUNCTION: Transfers the contents of a field in memory, one byte at a 
time, to another field in memory; the field lengths may vary from 
0-255 bytes. 


QPERAND 1: A field in memory moved one byte at a time. The field 
length 0-255 bytes, is specified by the L} value in the instruction. 
Addressing options to the base address Mj include only indexing (Rj). 


OPERAND 2: The receiving field in memory. The field length, 0-255 
bytes, is specified in the Ly field of the instruction. Addressing op- 
tions to the base address Mg include only indexing (Ro). 


RESULTS: The resulting value resides at the operand 2 location. The 
following conditions may occur, depending on the values of Ly and 
Lo. 


e if L; = Lg, the number of bytes specified by L} is transferred. 

e If Ly] is less than Lg, the number of bytes specified by Ly is 
transferred, then blanks are used to fill operand 2. 

e@ If L} is greater than Lg, the number of bytes specified by Lo 
is transferred. 

o If Lj} = 0 and Lo # 0, the number of bytes specified by L2 is 
filled with blanks. — 

@e if Lj] = 0 and Lg = 0, no transfer is executed. 


Note: MOVX is a word move if L) and Ly are both even and the beginning 
addresses are both even. 
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Move Long @ 


0 9 11 12 13 15 


MOVL = My (L,Ry) »Mo (Ro) 


FUNCTION: Moves a field in memory to another location in memory. The 
length of both fields must be the same; this length can vary from 
0-65,535. 


OPERAND 1: A field in memory moved one byte at a time. The field 
length, 0-65,535 bytes, is specified by the L value in the instruction. 
Addressing options to the base address M; include only indexing (R}]). 
The effective address points to the most significant word of the field. 


OPERAND 2: The receiving field in memory. The field length, 0-65,535 
bytes, is specified by the L value in the instruction. Addressing 
options to the base address Mo include only indexing .(R2). The 
effective address points to the most significant word of the field. 


RESULTS: The resulting field resides at the operand 2 location. The 


sending field and receiving field may overlap. If L = 0, no move of 
data is executed. 


Note: MOVL is a word move if the length, L, is even and the beginning 
addresses are even. 


- EXAMPLE: MOVL- TAG(2000,6) ,HERE(7) 


A 2,000-byte field identified by TAG(2000,6) is moved to another memory 
location beginning at the address represented by HERE(7). 
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Move Memory - Memory 


0 7 8 9 11 12 13 15 


HOM 0m (58H (Ro ee ee 


FUNCTION: Transfers the contents of a one-word field in memory to 
another one-word field in memory. 


OPERAND 1: A one-word field in memory. Addressing options to the 
base address M, include indexing (Ry), indirect addressing (bit 8=1), 
or a combination of both. 


QPERAND 2: Same as operand | except use Mo, Ro, and bit 12=1]. 


RESULTS: The resulting value resides at the operand 2 location. 


EXAMPLE: MOVM @TAG(3),@HERE(6) 


A 16-bit field identified by @TAG(3) is moved to the field identified 
by @HERE (6). 
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Move Register - Regtster 


7 8 9 11 12 13 15 


0 
eo [a] re | 
“vOR ey 


FUNCTION: Transfers the contents of a one-word field to another one- 
word field; either field may be in a general register or in memory. 


OPERAND 1: A one-word field in the general register specified by Ry 
or in memory if indirect addressing is used, bit 8=1. 


OPERAND 2: Same as operand | except use Ro and bit 12=]. 


RESULTS: The moved value resides at the operand 2 location. 


EXAMPLE: MOVR  @6,@4 


A 16-bit field at the address specified in register 6 is moved to the 
address specified in register 4, 
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Program Address Store 


PSTR = @R 


FUNCTION: Transfers the current program address to a one-word field 
in a register or in memory. 


OPERAND: A one-word field in the general register specified by R or 
in memory if indirect addressing is used, bit 12=1. 


RESULTS: The current program address resides at the operand | location. 


EXAMPLE: PSTR @5 


Transfers the current value of the Program Address register to the address 
specified in register 5. 
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Store Byte e 


0 7 8 9 11 12 13 15 


STOB eH(R) 6R, ee ee 


M 


FUNCTION: Transfers the contents of bits 8-15 of a general register or 
a one-byte field in memory to a one-byte field in memory. 


QPERAND 1: The receiving field; it is a one-byte field in memory. 
Addressing options to the base address M include indexing (Ry), 
indirect addressing (bit 8=1), or a combination of both. 


QPERAND 2: The field to be stored; bits 8-15 of the general register 
specified by Rog or in memory if indirect addressing is used, bit 12=1. 


RESULTS: The stored byte resides at the operand | location. 


EXAMPLE: STOB @TAG(3),4 


The contents of bits 8-15 of register 4 are stored at a memory location 
identified by @TAG(3). 
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Store Memory - Register 


7 8 9 11 12 13 15 


. 0 
STO @M(R)),8Rp ee ae 


FUNCTION: Transfers the contents of a one-word field in a general 
register or in memory to another one-word field in memory. 


OPERAND 1: The receiving field; it is a one-word field in memory. 
Addressing options to the base address M include indexing (Rj), 
indirect addressing (bit 8=1), or a combination of both. 


OPERAND 2: The field to be stored; it is a one-word field in the 
general register specified by Rg or in memory if indirect addressing 
is used, bit 12=1. . 


RESULTS: The field Is stored in the operand | location. 


EXAMPLE: STO @TAG(3),4 


The contents of register 4 are stored at a memory location identified 
by @TAG(3).- 
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Store Two-Word 


0 7 8 9 11 12 13 15 


STOT @M(R}) ,@Ro sh A) at me | 


FUNCTION: Transfers the contents of a two-word field in two general 
registers or in memory to a two-word field in memory. 


OPERAND 1: The receiving field; a two-word field in memory. Addressing 
options to the base address M include indexing (Rj), indirect addressing 
(bit 8=1), or a combination of both. 


OPERAND 2: The field to be stored; a two-word field in two general 
registers (the most significant word in the register specified by R2 
and the least significant word in the register specified by R2+1) or 
in memory if indirect addressing is used, bit 12=]. 


RESULTS: The stored values reside at the operand | location. 


EXAMPLE: STOT @TAG(2),@7 


A 32-bit field, the address of which is specified in register 7, is 
stored in memory at a location identified by @TAG(2). 
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NO OPERATION 


Mnemonic Code Name. 


NOP No Operation 
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No Operatton 


NOP 


FUNCTION: Performs no operation. This instruction has no operands. 


EXAMPLE: NOP 


This instruction occupies four bytes in the program. 
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SERVICE REQUEST 


Mnemonic Code Name 


SR Service Request 
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Service Request 


| 
— a ae | 


FUNCTION: Provides an information byte called the request index (1) 
to be interpreted by the operating system (software). The request 
index byte has the following format: 


P bit Indicates location of parameter string. 


0 means immediately following service request. 
] means at address contained in register 6. 


C bit Indicates when control is to be returned to requesting 
program. 


O means after service request is completed. 
l means after service request is recognized by 
the control program. 


E bit Indicates if the requesting program will process exception 
completion of the request. 


0 means requesting program will not process exception 
completion. 

] means requesting program will process exception 
completion. 


CLASS Denotes major class in which the service request falls. 
Service requests fall into the following seven major 
classes. 

CLASS 0 Debugging service request. 

CLASS 1 Restricted service request. 

CLASS 2 Control program service request. 
CLASS 3 Block !/0 service request. 

CLASS 4 Physical 1/0 service request. 

CLASS 5 Supervisor service request. 

CLASS 6 Telecommunications service request. 


NOTE: This material on the Service Request instruction does not 

cover all the necessary details; parameter strings, for instance, must 
be preceded by a four-byte field that further defines the operation. 
For more information on service requests, see the Operating System 
specifications. 
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OPERAND: | is the request index byte, which is defined by the overa- 
ting system. : 


RESULTS: Execution of a service request instruction causes the 
fol lowing: 


@ The Service Request bit (bit 13) of the executing processor's 
Condition register is set. 

@ The Busy and Active bits of Processor 4 are both set. 

e The Busy and Active bits of the executing processor are both 
reset. 
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SHIFT INSTRUCTIONS 


Mnemonic Code Name 

ARDR Arithmetic Right Double Shift - by 
Register 

ARDI Arithmetic Right Double Shift - 
Immediate 

ARSR Arithmetic Right Single Shift - by 
Register 

ARS] Arithmetic Right Single Shift - 
Immediate 

LLDR Logical Left Double Shift - by 
Register 

LLDI Logical Left Double Shift - Immediate 

LLSR Logical Left Single Shift - by 
Register 

LLS| Logical Left Single Shift - Immediate 

LRDR Logical Right Double Shift - by 
Register 

LRDI Logical Right Double Shift - Immediate 

LRSR Logical Right Single Shift - by 
Register 

LRS| Logical Right Single Shift - Immediate 

RLDR Rotating Left Double Shift - by 
Register 

RLDI Rotating Left Double Shift - Immediate 

RLSR . Rotating Left Single Shift - by 
Register . 

RLSI Rotating Left Single Shift - Immediate 

SHFK Shift Packed Decimal e 
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Artthmette Right Double Shtft — by Register 


ARDR  @Rq,Ro 


FUNCTION: Performs an arithmetic right shift of a two-word field in 
two general registers. The sign (bit 0) of the field is extended. 
The shift count is a 4-bit field in a general register or in memory. 


OPERAND 1: A 4-bit unsigned value located in the general register 
specified by Ry] or in memory if indirect addressing is used, bit 8=1. 
The shift count may range from 0-15. 


OPERAND 2: A two-word field in two general registers: the most 
significant bits in the register specified by Ry and the least 
significant bits in the register specified by Rgt+l. The data is 
shifted to the right the number of positions specified by operand |. 
The sign of the data is extended. Any data shifted out of the higher 
register is lost. (Note: If register 7 is specified as operand: 2, 
the operand is assumed to be in registers 7 and 0 with the most 
significant bits in 7.) 


EXAMPLE: ARDR- @3,5 
Shifts the data in registers 5 and 6 to the right; register 3 con- 


tains the address of a memory field that holds the shift count. 
The sign is extended, and data shifted out of register 5 is lost. 
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Artthmette Right Double Shift — Immedtate 


ARD! 1,R 


FUNCTION: Performs an arithmetic right shift of a two-word field in 
two general registers. The sign (bit 0) of the field is extended. 
The shift count is a 4-bit immediate value. 


QPERAND 1: A 4-bit unsigned value located in bits 8-11 of the instruc- 
tion; the shift count may range from 0-15. 


OPERAND 2: A two-word field in two general registers: the most 
significant bits in the register specified by R and the least 
significant bits in the register specified by R+]l. The data is 
shifted to the right the number of positions specified by operand |. 
The sign of the data is extended. Any data shifted out of the higher 
register is lost. (Note: If register 7 is specified for operand 2, 
the operand is assumed to be in registers 7 and O with the most 
significant bits in 7.) 


EXAMPLE: ARD! 1355 


Shifts the data in registers 5 and 6 to the right 13 bit positions. 
The sign is extended from bits 0-13 in register 5; data shifted out 
of register 6 is lost. 
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Arithmetic Right Single Shtft — by Register 


ARSR @R1,R, 


FUNCTION: Performs an arithmetic right shift of a one-word field in 
a general register. The sign (bit 0) of the field is extended. The 
shift count is a 4-bit field in a general register or in memory. 


OPERAND 1: A 4-bit unsigned value located in the general register 
specified by Ry or in memory if indirect addressing is used, bit 8=1. 
The shift count may range from 0-15. 


QPERAND 2: A one-word field in the general register specified by Ro. 

The data is shifted to the right the number of positions specified by 

operand |. The sign of the data is extended. Any bits shifted out of 
the register are lost. 


EXAMPLE: ARSR @5,4 
Shifts the data in register 4 to the right; register 5 contains the 


address of the shift count. The sign is extended, and data shifted 
out of register 4 is lost. 
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Arithmette Right Stngle Shift — Immediate 


ARS! 1, , 


FUNCTION: Performs an arithmetic right shift of a field in a general 
register. The sign (bit 0) of the field is extended. The shift 
count is a 4-bit immediate value. 


OPERAND 1: A 4-bit unsigned value located in bits 8-11 of the instruc- 
tion; the shift count may range from 0-15. 


OPERAND 2: A one-word field in the general register specified by R. 
The data is shifted to the right the number of positions specified by 


operand 1. The sign of the data is extended. Any data shifted out 
of the register is lost. 


EXAMPLE: ARSI 11,2 


Shifts the data in register 2 to the right 1] bit positions. The sign 
is extended from bit 0-11; any data shifted out of register 2 is lost. 


3-154 . 2999.001 


FOR MEMOREX INTERNAL USE ONLY 


Logteal Left Double Shift — by Regtster 


0 7 8 9 11 12 13 15 


LLDR @R}., Ro 


FUNCTION: Performs a left shift (zero fill from right) of a two- 
word field in two general registers. The shift count is a 4-bit 
field in a general register or in memory. 


OPERAND 1: A 4-bit unsigned value located in the general register 
specified by Rj or in memory if indirect addressing is used, bit 8=1. 
The shift count may range from 0-15. — 


OPERAND 2: A two-word field in two general registers: the most 
significant bits in the register specified by Rg and the least 
significant bits in the register specified by Ro+!l. The data is 

shifted to the left the number of positions specified by operand 1. 

Any data shifted out of the lower register is lost. (Note: If register 
7 is specified for operand 2, the operand is assumed to be in registers 
7 and 0 with the most significant bits in 7.) 


EXAMPLE: LLDR @2,3 


Shifts the data in registers 3 and 4 to the left; the address of the 
shift count is in register 2. Data shifted out of register 3 js lost. 
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Logteal Left Double Shift — Immediate 


0 7 8 11 12 13 15 


LOI 1k ! 


FUNCTION: Performs a left shift (zero fill from right) of a two-word 
field in two general registers. The shift count is a 4-bit immediate 
value. 


QOPERAND 1: A 4-bit unsigned value located in bits 8-11] of the 
instruction; the shift count may range from 0-15. 


OPERAND 2: A two-word field in two general registers: the most 
significant bits in the register specified by R and the least 
significant bits in the register specified by R+]l. The data is 
shifted to the left the number of positions specified by operand 1. 
Any data shifted out of the lower register is lost. (Note: If 
register 7 is specified for operand 2, the operand is assumed to be 
in registers 7 and 0 with the most significant bits in 7.) 


EXAMPLE: LLDI 10,0 


Shifts the data in registers 0 and | to the left 10 bit positions. 
Data shifted out of register 0 is lost. 
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Logteal Left Single Shift — by Register 


0 | 78 9. 111213 15 


LLSR @R], Ro 


- FUNCTION: Performs a left shift (zero fill from right) of a one-word 
field in a general register. The shift count is a 4-bit field ina 
general register or in memory. 


QPERAND.1: A 4-bit unsigned value in the general register specified 
by Ry} or in memory if indirect addressing is used, bit 8=1, The shift 
count may range from 0-15. 

OPERAND 2; A one-word .field in the general register specified by Ro. 


The data is shifted to the left the number of positions specified bY 
operand 1. Any data shifted out of the Fag) ser is lost. 


EXAMPLE: LLSR @2,7 


Shifts the data in register 7 to the left; the address of the shift 
count is in register 2. Data shifted out of register 7 is lost. 
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Logteal Left Single Shift — Immediate 


0 7 8 11.12 13 15 


US! 1k 1 


FUNCTION: Performs a left shift (zero fill from right) of a one-word 
field in a general register. The shift count is a 4-bit immediate 
value. 


QPERAND 1: A 4-bit unsigned value located in bits 8-11 of the instruc- 
tion; the shift count may range from 0-15. 


OPERAND 2: A one-word field in the general register specified by R. 


The data is shifted to the left the number of positions specified by 
operand 1. Any data shifted out of the register is lost. 


EXAMPLE: LLSI 7,5 


Shifts the data in register 5 to the left 7 bit positions. Data 
shifted out of register 5 is lost. 
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Logteal Right Double Shtft — by Register 


0 78 9 111213 15 


LRDR @R Ro 


FUNCTION: Performs a right shift (zero fill from left) of a two-word 
field in two general registers. The shift count is a 4-bit field in 
a general register or in memory. 


OPERAND 1: A 4-bit unsigned value located in the general register 
specified by Rj or in memory if indirect addressing is used, bit 8=1. 
The shift count may range from 0-15. 


OPERAND 2: A two-word field in two general registers: the most 
significant bits in the register specified by Ro and the least 

significant bits in the register specified by Ro+1l. The data is 

shifted to the right the number of positions specified by operand 1. 

The sign of the data is not extended. Any data shifted out of the 

higher register is lost. (Note: If register 7 is specified as 

operand |, the operand is assumed to be in registers 7 and 0 with the most 
significant bits in 7.) 


EXAMPLE: LRDR 67,4 
Shifts the data in registers 4 and 5 to the right. The shift count 


is at the memory address specified in register 7. Data shifted out 
of register 5 is lost. 
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Logical Right Double Shift — Immediate 


0 7 8 11.1213 15 


LRDI 1,R 


FUNCTION: Performs a right shift (zero fill from left) of a two-word 
field in two general registers. The shift count is a 4-bit immediate 
value. ; 


OPERAND 1: A 4-bit unsigned value located in bits 8-11 of the instruc- 
tion; the shift count may range from 0-15. 


OPERAND 2: A two-word field in two general registers: the most 
significant bits in the register specified by R and the least 
significant bits in the register specified by Rt]. The data is 
shifted to the right the number of positions specified by operand 1. 
Any data shifted out of the higher register is lost. (Note: If 
register 7 is specified for operand 2, the operand is assumed to be 
in registers 7 and 0 with the most significant bits in 7.) 


EXAMPLE: LRDI 10,0 


Shifts the data in registers 0 and | to the right 10 bit positions. 
Data shifted out of register 1 is lost. 
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Logteal Right Single Shift — by Register 


0 7.8 9 111213 15 


LRSR- = @R],Ro 


FUNCTION: Performs a right shift (zero fill from left) of a one- 
word field in a general register. The shift count is a 4-bit field 
in a general register or in memory. 


OPERAND 1: A 4-bit unsigned value located in the general register 
specified by Rj] or in memory if indirect addressing is used, bit 8=1. 
The shift count may range from 0-15. 


QPERAND 2: A one-word field in the general register specified by Ro. 
The data is shifted to the right the number of positions specified 

by operand 1. The sign is not extended. Any data shifted out of the 
register is lost. 


EXAMPLE: LRSR @3,5 


Shifts the data in register 5 to the right; the address of the shift 
count is in register 3. Data shifted out of register 5 is lost. 
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Logical Right Single Shift — Immedtate 


FUNCTION: Performs a right shift (zero fill from left) of a one-word 
field in a value. 


OPERAND 1: A 4-bit unsigned value located in bits 8-11 of the instruc- 
tion; the shift count may range from 0-15. 


OPERAND 2: A one-word field in the general register specified by R, 
The data is shifted to the right the number of positions specified 


by operand 1. The sign of the data is not extended. Any data shifted 
out of the register is lost. 


EXAMPLE: LRSI 7,5 


Shifts the data in register 5 to the right 7 bit positions. Data 
shifted out of the register is lost. 
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Rotating Left Double Shtft — by Register 


RLDR @R ,R, 


FUNCTION: Performs a rotating left shift of a two-word field in two 
general registers. The shift count is a 4-bit field in a general 
register or in memory. 


OPERAND 1: A 4=bit unsigned value located in the general register 
specified by Ry} or in memory if indirect addressing is used, bit 8=1, 
The shift count may range from 0-15. 


OPERAND 2: A two-word field in two general registers: the most 
significant bits in the register specified by Rg and the least 
significant bits in the register specified by Ro+l. The data is 

shifted to the left the number of positions specified by operand 1. 

Each bit shifted out of the left end of the lower register is brought 
back in the right end of the higher register. Bits shifted out of the 
register are not lost. (Note: If register 7 is specified as operand 1, 
the operand jis assumed to be in registers 7 and 0 with the most 
significant bits fn 7.) 


EXAMPLE: RLDR @5,2 


Shifts the data in registers 2 and 3 to the left; the shift count is 
at the memory location specified in register 5. Data shifted out 
the left end of register 2 is brought back in the right end of 
register 3. 
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Rotating Left Double Shift — Immedtate 


0 7 8 11 12 13 15 


RLDI 4,R 


FUNCTION: Performs a rotating left shift of a two-word field in two 
general registers. The shift count is a 4-bit immediate value. 


QPERAND 1: A 4-bit unsigned value located in bits 8-11 of the 
instruction; the shift count may range from 0-15. 


OPERAND 2: A two-word field located in two general registers: the 
most significant bits in the register specified by R and the least 
significant bits in the register specified by R+l. The data is 
shifted to the left the number of positions specified by operand |. 
Each bit shifted out of the left end of the lower register is brought 
back in the right end of the higher register. Bits shifted out of 
the lower register are not lost. (Note: If register 7 is specified 
as operand |, the operand is assumed to be in registers 7 and O with 
the most significant bits in 7.) 


EXAMPLE: RLDI 6,1 


Shifts the data in registers 1 and 2 to the left six bit positions. 
Each bit shifted out of the left end of register 1 is brought back 
in the right end of register 2. 
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Rotating Left Single Shtft — by Register | 


RLSR  @Ry Ro 


FUNCTION: Performs a rotating left shift of a one-word field ina 
general register. The shift count is a 4-bit field in a general 
register or in memory. 


QPERAND 1: A 4-bit unsigned value located in the general register 
specified by Ry or in memory if indirect addressing is used, bit 8=1. 
The shift count may range from 0-15. 


OPERAND 2: A one-word field in the general register specified by Ro. 
The data is shifted to the left the number of positions specified by 
operand |. Each bit shifted out the left end of the register is brought 
back in the right end. Bits shifted out of the register are not lost. 


EXAMPLE: RLSR_ @1,2 
Shifts the data in register 2 to the left. Data shifted out the left 


end of the register is brought back in the right end of the register. 
The shift count is at the memory address in register |. 
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Rotating Left Single Shift — Immediate 


FUNCTION: Performs a rotating left shift of a one-word fieid ina 
general register. The shift count is a 4-bit immediate value. 


OPERAND 1: A 4-bit unsigned value located in bits 8-11 of the instruc- 
tion; the shift count may range from 0-15. 


OPERAND 2: A one-word field located in the general register specified 
by R. The data is shifted to the left the number of bit positions 
specified by operand 1. Bits shifted out of the register are not lost; 
each bit shifted out of the left end of the register is brought back 

in the right end of the register. 


EXAMPLE: RLSI 552 
Shifts the data in register 2 to the left 5 bit positions. Data 


shifted out the left end of the register is brought back in the right 
end; no bits are lost. 
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Shtft Packed Decimal 


SHFK M(L,Ry), 1 (Ra) 


FUNCTION: Shifts a packed decimal field in memory a specified number 
of digits. The length of the packed decimal field can be defined for 
each SHFK instruction. 


QOPERAND 1: The packed decimal field in memory. The length of this 
field (number of decimal digits) is in L; this value may range from 
0-255. Addressing options to the base address M include only in- 
dexing (R}). 


OPERAND 2: The shift count is the | value in the instruction, this 
is a signed value from -128 to +127. If a register is specified in 
Ry, the contents of the register are added to the | value to form the 
shift count. 


CONDITION REGISTER: 


e Bit 0 is set if any significance is shifted out ina 
left shift; otherwise bit 0 is cleared. 

e Bit 1 is set if the result is positive; otherwise bit 
1 is cleared. 

e Bit 2 is set if the result is negative; otherwise bit 
2 is cleared. 

e Bit 3 is set if all significance is shifted out, 
resulting in zero, or if L=0; otherwise bit 3 is 
cleared. 


EXAMPLE: SHFK TAG(90,2) ,14(5) 


The contents of location TAG are modified by the contents of register 
2 to find a 90-byte packed decimal field, which is shifted 14 bit 
positions (modified by register 5) to the right. 
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SECTION V 
SYSTEM CONTROL PANEL 


INTRODUCTION 


This section describes the function of controls and indicators associated 
with the operator group, programmer group, system activity display group, 
and communication activity display group. Description of controls, indi- 
cators, and procedures associated with the maintenance group portion of 
the panel are specifically excluded from this section because their use 
is restricted to properly-qualified maintenance personnel only. 


CONTROLS AND INDICATORS 


Controls and indicators on the System Control Panel are divided into 
five groups: 


@ Operator Group 

e Programmer Group 

@ Maintenance Group 

e System Activity Display Group 

e Communications Activity Display Group 
The following paragraphs provide a functional description for each 
control and indicator on the panel. The descriptions are arranged by 


panel group, starting with the bottom right control in each group and 
proceeding in a leftward and upward manner. 
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Operator Group 


@ EMERGENCY PULL Knob 


When pulled, instantly removes all power from system (does 
not go through normal power-down sequence which Is the case 
when using POWER OFF pushbutton). 


NOTE: The EMERGENCY PULL knob is not meant for normal 
"power-off"! sequencing. Whenever this switch is used to 
remove power from the system, power cannot be reapplied untt] 
a mechanical inter-lock within the cabinet is released. 

(This is a malntenance activity.) Thus the EMERGENCY PULL 
knob is intended to be used only in emergency situations 
(circumstances Involving a safety hazard). 


@ POWER OFF Pushbutton/Indicator 


Turns system power off when POWER MODE switch in the Mainten- 
ance Group is in LOCAL. This switch assures proper power- 
down sequencing. (POWER OFF has no effect while POWER MODE 
is in REMOTE.) 


NOTE: POWER OFF will be illuminated unless no primary 
power is available, the Main Disconnect switch is off, the 
EMERGENCY PULL knob has been pulled, or power fs on (that 
period between the completion of a power-up sequence and 
the initialization of a power-down sequence). 


@ POWER ON Pushbutton/ Indicator 


Turns system power on when the POWER MODE switch in the 
Maintenance Group is in LOCAL. This switch assures proper 
power-up sequencing. (POWER ON has no effect while POWER 
MODE ts in REMOTE.) 


NOTE: Upon completion of the power-up sequence, a Reset/Load 

sequence {is automatically initiated. Moreover, at completion 

of the Reset/Load sequence, an Autoload sequence Is auto- 

matically initiated provided the Maintenance Mode has not been 

selected. Further detail is provided under Reset/Load, Auto- 
_ Joad, and Maintenance Mode in this section. 


‘e@ AUTOLOAD Pushbutton 
Causes Main Storage to be loaded, starting at a location deter~ 
mined by the microprogram subroutine with data obtained 
either from disc drive zero (when AUTOLOAD SELECT switch is 
in PRIMARY) or from a card reader (when AUTOLOAD SELECT 
switch is in ALTERNATE). 
@ AUTOLOAD SELECT Switch 


Down position (PRIMARY) selects disc as Input device. Up 
position (ALTERNATE) selects card reader as input device. 
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NOTE: The PRIMARY position of this switch causes the first 
Autoload microprogram loader instruction to come from 
Control Storage address 0113;¢. The ALTERNATE position of 
this switch causes the first autoload microprogram loader 
instruction to come from Control Storage address 0112]¢. 
This switch also determines the device, as defined above, 
that Control Storage is loaded from during a Reset/Load 
operation. 

SPEAKER VOLUME Control 

Adjusts volume of the speaker contained in the System Control 
Panel enclosure. This speaker is driven by the circuits 
associated with bit positions 13, 14, and 15 of the Console 
Data Register Display indicators. 

NOTE: The relative loudness of these bits on the speaker 
are: bit 14 will be twice as loud as bit 13 and bit 15 
twice as loud as bit 14. 

1/0 FAULT Pushbutton/Indicator 


1/0 FAULT will illuminate if any of the following conditions 
occur. 


1. Channel 1 Transmission Parity Error 
2. Channel 2 Transmission Parity Error 
3. Channel 1 Control Check Error 
4, Channel 2 Control Check Error 


5. Burst Check Error (during a Reset/Load operation from 
disc). 


6. Failure of disc heads to retract during power-down 
sequence 


Pressing 1/0 FAULT extinguishes the indicator. (Refer to 
individual 1/0 fault indications in the System pe ney 
Display Group, further in this section.) 


PROC FAULT Pushbutton/Indicator 


PROC FAULT will illuminate if any of the following conditions 
occur. 


1. Control Storage Parity Error 
2. Main Storage Parity Error 
3. DC Voltage Fault 


4, OQver-Temperature condition 
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Pressing PROC FAULT extinguishes the indicator. 


ALARM (located behind System Control Panel) 


Furnishes an audible signal when the LAMP TEST pushbutton 
is depressed or when any of the following conditions exist. 


1. Blower failure within the computer 
2. D.C. voltage fault 


3. Failure of disc heads to retract during a power-down 
sequence 


NOTE: When blower failure or D.C. fault condition exists for 
approximately 60 seconds, the power-down sequence is auto- 
matically initiated. 


If the heads fail to retract from a disc during the power- 
down sequence, DC voltages will be removed within the computer. 
The power-down sequence will stop at that point until the 
problem is corrected. 


ALARM DISABLE Pushbutton/Indicator 


Pressing this pushbutton, if the audible alarm is on, causes 
the ALARM to stop and the ALARM DISABLE to illuminate. When 
the alarm condition is corrected, the ALARM DISABLE will 
extinguish. 


LAMP TEST Pushbutton 


Pressing this switch causes all indicators to illuminate 
and the alarm to sound. Releasing the switch returns them 
to their prior state. 


RESET/LOAD Pushbutton 


Causes data to be read from either cards or disc and 
transferred to either Control Storage and first-level decode 
address table or Main Storage, depending on whether the 
CONSOLE MODE SELECT selector is set to CS-WR or MS-WR and if 
the Maintenance Mode has been selected. Selection of 

cards or disc as input medium is determined by position of 
AUTOLOAD SELECT switch. 


Upon completion of a Reset/Load operation from disc, an 


Autoload operation will automatically be initiated pro- 
viding the Maintenance Mode has not been selected. 
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Programmer Group 
NOTE: Controls within this group are conditioned by the 
PROGRAM MODE pushbutton/indicator except where otherwise 
designated. 
@ CONSOLE MODE SELECT Selector 
Selects basic mode of operation for System Control Panel: 
RO-RD - Register Option read 
RO-WR - Register Option write 
RF-WR - Reaister File write 
RF-RD - Register File read 
OFF - select switch disabled 
MS-RD - Main Storage read 
MS-WR - Main Storage write 
CS-RD ~- Control Storage and first-level decode address 
table read or scan (enabled in Maintenance 


Mode only) 


CS-WR - Control Storage write (enabled in Maintenance 
Mode only except during a Reset/Load operation) 


@ CONSOLE RUN Pushbutton 
Initiates the function selected on the CONSOLE MODE SELECT 
selector in a manner determined by the CONSOLE CONTROL 
SELECT and Console MS switches. 

@e CONSOLE CONTROL SELECT Switch 


Three-position switch governing way in which selected console 
control operation is executed: 


STOP/STEP - stop and step 
NORMAL - run continuously 
BREAKPOINT - run as far as breakpoint (applies to 


CS-RD, CS-WR, MS-RD, and MS-WR only) 
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e Console Main Storage Switch 


NOTE: This switch has no effect unless the Relocation and 
Protection feature is installed. 


When Console Mode Selector is set to MS-RD or MS-WR this switch 
determines whether the contents of the S-Register is inter- 
preted as a System or Physical Main Storage Address. When in 
the RELOCATE (up) position, the contents of the S-Register are 
interpreted as a System Main Storage address and is converted 
by the relocation mechanism into a Physical Main Storage 
Address. When in the OFF (down) position, the contents of 
the S-Register is directly interpreted as a Physical Main 
Storage Address and will bypass the relocation mechanism. 

@® SYSTEM RESET Pushbutton 


The SYSTEM RESET pushbutton clears the following registers: 


1. EXTENDED REGISTER FILE 

Group I: Pu of all processor states 

Group Il: Busy/Active, Tie-Breaker, Control, Privileged, 

Boundary-Crossing, Control Storage Scan, 
Console Address, and Console Data. 

2. SHARED RESOURCE REGISTERS 

Au, Bu, D, Su, Furl, Fu-2, and Forced Carry Register 

@ PROGRAM MODE Pushbutton/ Indicator 
Pressing this switch enables those switches located in the 
programmer group area of the panel unless otherwise indicated. 
The pushbutton is illuminated when Program Mode is selected. 
@ CONSOLE DATA REGISTER SELECT Selector 

Selects one of eleven registers to be displayed by the 
CONSOLE DATA REGISTER DISPLAY indicators. (Does not affect 
the pushbutton function.) 
NOTE: Only the DATA and B/A positions are enabled when Program 
Mode is selected. All other positions of this switch require 
Maintenance Mode to be effective. 
Fu2 <- Micro-command Function register, rank 2 
Ful - Micro-command Function register, rank | 
RTC - Real-Time Clock register 
CSS - Control Storage Scan register 


B/A - Busy/Active register 
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DATA - Console data register 


D - Main Storage Data register 
Au - ALU feeder register Ap 
Bu - ALU feeder register Bu 


SUM = output of ALU (sum of Au and By) 
BC - Boundary-Crossing register 
e@ CLEAR DATA Pushbutton 
Clears contents of Console Data Register. 
@ CONSOLE DAi.\ REGISTER DISPLAY Pushbutton/Indicators 


Twenty pushbutton/indicators horizontally located as 5 
groups of 4 bits each. These groups function as follows: 


1. Pushbutton/indicators: XO - X3 


These pushbutton/indicators are not functional un- 
less the Relocation and Protection Feature is present 
in the 7200/7300 computer. 


In the presence of the Relocation and Protection 
feature, pressing these pushbuttons will cause cor- 
responding bits to be set in the Segment Tag portion 

of the Console Data Register. The indicators will be 
on for corresponding bit positions that are set and off 
for corresponding bit positions that are clear in the 
Segment Tag portions of the Console Data Register. 


2. Pushbutton/indicators: 00 - 15 


Pressing these pushbuttons will cause corresponding 
bits to be set in the Console Data Register only. How- 
ever, the indicators will be on for corresponding bit 
positions that are set and off for corresponding bit 
positions that are clear at Fu2, Ful, RTC, CSS, B/A, 
DATA, D, Au, Bu, SUN or BC outputs as determined by the 
CONSOLE DATA REGISTER SELECT Selector. 


The digital inputs to the Console Data Register Display 
lamp drivers in bit positions 13, 14, and 15 are also 
used as inputs to the panel speaker drivers. 
@ CONSOLE ADDRESS REGISTER SELECT Selector 
Selects one of four registers to be displayed by the 


CONSOLE ADDRESS REGISTER DISPLAY indicators. (Does not 
affect the Console Address Register pushbutton function.) 
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NOTE: Only the S$ and ADDRESS positions are enabled when 
Program Mode is selected. The remaining positions of this 
switch require Maintenance Mode to be effective. 


S - Main Storage address register 
Su ~ Control Storage address register 
ADDRESS - Console Address register 


PE - Main Storage Parity Error address 
register 


@e CLEAR ADDRESS Pushbutton 
Clears contents of Console Address Register. 
@ CONSOLE ADDRESS REGISTER DISPLAY Pushbutton/Indicators 


Twenty pushbutton/indicators horizontally located as 5 
groups of 4 bits each. These groups function as follows: 


1. Pushbutton/indicators: XO - X3 


These pushbutton/indicators are not functional unless 
the Relocation and Protection Feature is present 
in the 7200/7300 computer. 


In the presence of the Relocation and Protection 
Feature, pressing these pushbuttons will cause cor- 
responding bits to be set in the Segment Tag Portion 

of the Console Address Register. The indicators will be 
on for corresponding bit positions that are set and off 
for corresponding bit positions that are clear in the 
Segment Tag portions of the S, Console Address, and 

PE Registers as determined by the CONSOLE ADDRESS 
REGISTER SELECT Selector. 


2. Pushbutton/indicator: 00 - 15 


Pressing these pushbuttons will cause corresponding 
bits to be set in the Console Address Register only. 
However, the indicators will be on for corresponding 
bit positions that are set and off for corresponding 
bit positions that are clear in the Su, S, Console 
Address and PE Registers as determined by the CONSOLE 
ADDRESS REGISTER SELECT Selector. 


@ BREAKPOINT MODE SELECT Switches: 
1. WRITE DATA Switch 
When up (on), causes breakpoint stop at end of each storage 
reference cycle in which data was written at breakpoint 
address. 


2. READ DATA Switch 


When up (on), causes breakpoint stop at end of each storage 
reference cycle in which data was read at breakpoint 
address. 
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3. READ INSTR Switch 


When up (on), causes breakpoint stop immediately after 
the machine language instruction is read at breakpoint 
address. 


4, SYSTEM/PHYSICAL Switch 


NOTE: This switch has no effect unless the Relocation 
and Protection Feature is installed. 


This switch determines whether the System or Physical 
Main Storage Address is compared with the Breakpoint 
Address SELECT. Additionally, this switch determines 
whether the System or Physical Main Storage Addresses 
are sent to the Console Address Register Display indica- 
tors when the Console Address Register Select switch 

is set to the S position. When in the SYSTEM (up) posi- 
tion, System Main Storage Addresses are selected as 
described above. When in the PHYSICAL (down) position, 
Physical Main Storage Addresses are selected as de- 
scribed above. 


BREAKPOINT ADDRESS SELECT Selectors 

Five selectors which provide a hexadecimal stop address 

for processor state(s) operating in the breakpoint mode. 

Also applies to console mode, MS-RD, MS-WR, and CS~-WR selections. 
PROCESSOR SELECT Selector 

Selects one of the eight processor states to execute in 

the mode selected by the corresponding Processor Control 

Select switches. 


PROCESSOR RUN Pushbutton 


Starts the processor state selected by the PROCESSOR 
SELECT selector. 


PROCESSOR CONTROL SELECT Switches 


Eight three-position switches which place individual 
processor states in one of three modes: 


1. STOP/STEP - Stop and step selected processor 
state. 


2. NORMAL - Allows selected processor state to run 
continuously. 


3. BREAKPOINT - Allows selected processor state to run 


until a breakpoint-comparison equality 
occurs. 
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System Activity Display Group 


PROCESSOR STATE Indicators 


Dynamically indicate which processor states are executing 
major cycles. 


Status Indicators 
Twelve indicators that illuminate particular status conditions: 


MS PARITY BYTE 0 - Displays state of parity bit of 
upper byte (bits 0 through 7) of word currently being 
read out of MS. (Not enabled if ECC is present.) 


MS PARITY BYTE 1 - Displays state of parity bit of 
lower byte (bits 8 through 15) of word currently 
being read out of MS. (Not enabled if ECC is present.) 


MS PARITY ERROR - Displays state of MS Parity 
Error flip-flop. Indicator is on if flip-flop is set 
and off if flip-flop is cleared. 


CS PARITY ERROR - Indicates a parity error in CS or 
first-level decode address table. 


D.C. FAULT - Indicates that one or more DC power 
supply in system is not within allowable output 
range. Remains on until condition is corrected. 


OVER TEMP. - Indicates a blower failure condition 
within cabinet. 


HEADS EXTENDED - Indicates that heads in one or more 
disc files fail to retract during the power-down 
sequence. 


BURST CHECK - Indicates detection of a. burst check 
error during a Reset/Load sequence from the disc file. 


CHANNEL 1 DATA CHECK - Indicates state of Channel 
1] Transmission flip-flop. 


CHANNEL 1 CNTRL. CHECK - Indicates state of Channel 
1 Control Check flip-flop. 


CHANNEL 2 DATA CHECK - Indicates state of Channel 2 
Transmission flip-flop. 


CHANNEL 2 CNTRL. CHECK - Indicates state of Channel 
2 Control Check flip-flop. 
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Maintenance Group 


Controls and indicators of the maintenance group are not described 
in this manual because their use is restricted to maintenance per- 
sonnel only. 


Communications Line Display Group 


These indicators show the adapter/modem status for the 15 communications 
channels and the integrated communications adapter as follows. 


@ RECEIVED DATA (BB) - The ON condition indicates that the 
line is in the spacing condition (i.e., a binary zero). 
The OFF condition indicates that the line is in the mark- 
ing condition (i.e., a binary one). 


@ TRANSMITTED DATA (BA) - The ON condition indicates that 
the line is in the spacing condition (i.e., a binary zero). 
~The OFF condition indicates that the line is in the marking 
condition (i.e., a binary one). 


@ CLEAR TO SEND (CB) ~ The ON condition together with the 
ON condition on circuits CA, CC, and CD, indicates that the 
channel is in a transmit condition. 


e RECEIVED LINE SIGNAL DETECTOR (CF) - The ON condition 
indicates that the modem is receiving a signal which 
meets its suitability criteria for demodulation, and 
in the case of half-duplex channels, that the line adapter 
is in the receive mode. 


@ SECONDARY RECEIVED LINE SIGNAL DETECTOR (SCF) - The ON 
condition indicates the proper reception (where applicable) 
of the secondary channel line signal. It is used to 
indicate the circuit assurance status and to signal the 
interrupt condition. 


@ DATA SET READY (CC) - The ON condition on this circuit 
is presented to indicate that the modem is connected 
to a communication channel and has completed the trans- 
mission of the answer tone. 


@ OFF HOOK (OH) - When answering a call, this signal ulti- 
mately completes a d.c. path to the serving Central 
Office, tripping the incoming ringing signal. When 
originating a call, this lead is operated to obtain dial 
tone and then pulsed to generate the desired dial digits. 


@ RING INDICATOR (CE) - the ON condition indicates that a 
ringing signal is being received on the communication 
channel. 
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NOTE: Since under normal operation the communications 
handler will answer a call on the leading edge of the 
ring signal, the ON condition on this indicator implies 
either a malfunction or that the channel is not enabled. 


@ ENABLE (EN) - The ON condition indicates that the line 
adapter is enabled and is therefore not in the master 
clear or loop test mode. 


OPERATING PROCEDURES 


The following paragraphs contain procedures which may be executed from 
the System Control Panel. These procedures facilitate loading 

Control or Main Storage from either a disc or card reader, reading 
from or writing into Main Storage or registers within Register Files 
or Register Options and executing programs in Maintenance Mode. 


@ SWITCHING POWER ON 


To turn the computer on, ensure that the LOCAL/REMOTE switch 
is in the LOCAL position, then simply depress the POWER ON 
pushbutton/indicator. Upon completion of the power-up 
sequence, the associated indicator will light. 


The internal power-up switching sequence for the computer 
and disc drives is performed by the hardware. 


To turn the computer off, depress the POWER OFF pushbutton/ 
indicator. The associated indicator will light. 


@ FUNDAMENTAL MODES 


Apart from the Reset/Load and Autoload facilities, which 

are always available to the operator, the System Control 

Panel proper (activated by the PROGRAM MODE and MAINTENANCE 
MODE) has two fundamental modes of operation. These two modes, 
Processor Control and Console Control, are not mutually 
exclusive from the hardware point of view, but should be 
clearly distinguished and kept separate in operating prac- 
tice. This separation is necessary since the Console Mode 

can directly alter the contents of storage and registers and 

in this way could completely disrupt Processor Mode operations. 


The Processor Control Mode enables the operator, in connec- 
tion with programmed operation, to directly control execu~ 
tion of instructions by all eight processor states. Thus, 
individual processors states may be switched on and off or 
may be made to run one instruction at a time (STEP mode) 
etc. Except for the internal effects of the programs them- 
selves, the Processor Mode does not enable the contents of 
storage to be altered. 
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The Console Control Mode,. on the other hand, does not involve 
any actual execution or instructions, but allows any indivi- 
dual cell of Main or Control Storage to be either displayed 
or altered. The console mode also allows any of the hard- 
ware registers to be displayed or altered. The console 
(System Control Panel) ts allocated major cycles just as 
though it were a ninth processor, except that it cannot exe- 
cute machine instructions. 


BREAKPOINT FACILITY 


The Breakpoint facility provides a way of terminating Proc- 
essor Mode or Console Mode operations at a specific point 

in efther Main Storage or Control Storage (including the 
first-level decode address table). This facility may be 
invoked if the selected processor is started either from 

the panel (Processor RUN) or by internal operations, or if 
the computer is already executing instructions. The Break- 
point operation is initiated by setting the Processor Control 
Select switch to BREAKPOINT. The computer then proceeds 
until the storage location on the BREAKPOINT ADDRESS SELECT 
is used for one of three purposes as selected on the three 
Breakpoint Mode switches. Read Instr will stop the selected 
processor when it reads an instruction from the Breakpoint 
address; Read Data will stop it when it reads an operand from 
the Breakpoint address and Write Data will stop it when it 
stores an operand at the Breakpoint address. 


With respect to the Breakpoint facility, a Read Data reference 
is only the loading of the first two bytes of an instruction. 
Thus, the reading of the Vj, Va, L,, and Ly portions of 4-, 
6-, and 8-byte instructions are treated as operand references 
for Breakpoint purposes. 


NOTE: Word addressing will not result tn a Breakpoint 
stop where the rtght-most byte address of the refer- 
enced word is designated tn the Breakpoint address 
switches. An example ts the case of MS-RD or MS-WR 
operattons whteh will not perform a breakpoint stop | 
tf any odd-numbered (right-most byte) address ts destg- 
nated by the BREAKPOINT ADDRESS SELECT. 


For console operations (when the CONSOLE CONTROL SELECT 
switch is set to BREAKPOINT), the stop will always occur 
at the end of the storage reference cycle in which data 
is read or written at the Breakpoint address. 


NOTE: The. Breakpoint facility is. not available for CS 
references in either Operator or Program Mode. 
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APPENDIX A 
COMPARISON OF 7200/7300 
PERFORMANCE CHARACTERISTICS 
PERFORMANCE CHARACTERISTICS 7300 7200 
M, -- Memory Reference Cycle Time 9 ys 1.8 ys 
1.0 us with ECC not available 
ECC | | 

M, — Non-memory Reference Cycle Time .8 ys 1.6 us 


2 


NOTE: The above times will be increased by .2 us if the computer is 
used for special purposes which require the machine to be run ina 
single processor state only. 
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APPENDIX B 
MNEMONIC CODE TO HEX CODE 


A2 CMPM 61 LLSR 2C 
B2 CMPR 2] LOD AO 
32 CMPT 71 LODB F7 
52 CMPX 20 LODD BO 
62 CSTR 2A LODI 30 
22 CTB 12 LODT 70 
72 CVB AA LRDI 5D 
A5 CVBT AA LRDR 3D 
BS CVD AB LRS| 4D 
35 CVDT AB LRSR 2D 
65 DIO F2 MOVB 6A 
25 DIV AQ MOVL SA 
5F DIVD B9 * MOVM 60 
3F DIVK = 7 MOVR 20 
LF DIVI 39 ~ MOVX Sk 
2F DIVM 69 MPY A8 
ED DIVR 29 MPYD B8 
E4 EDTX 57 MPYK 5B 
E5 EOR A6 MPY 1 38 
E9 EORD B6 MPYM 68 
EC EORI 36 MPYR 28 
EF EORM 66 NOP EE 
E8 EORR 26 OUT F6é 
E2 BIT BF PAKX 58 
E3 INP ID PSTR 3A 
EB INV A4 RAR FE 
E] INVD B4 RBA 10 
EO INV 34 RBIT BD 
E6 INVM = 64 RCN 14 
E7 INVR 24 RDC F3 
EA 1OR A7 RDX FO 
F9 1ORD B7 RLDI 5E 
6B IORI 37 RLDR 3E 
2B 1ORM 67 RLSI he 
Al IORR 27 RLSR 2E 
Bl LLDI 5C ROFR 6F 
31 LLDR 3C RONR 6D 
5] LLSI AC RPM 15 


2999.001 


SRMB 
SRMF 
SRNB 
SRNF 
SRPB 
SRPF 
SRZB 
SRZF 
STO 

STOB 
STOT 
SUB 

SUBD 
SUB I 
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SUBK 
SUBM 
SUBR 
SUBT 
TBIT 
TOFR 
TONR 
TRNX 
TST 

UNPX 
WAR 

WRC 

WRX 

ZADK 


53 
63 
23 
73 
BE 
6E 
6C 
56 
1 
59 
FE 
Fy 
FO 
50 
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APPENDIX C_ 
MACHINE LANGUAGE INSTRUCTION 
TIMING FORMULAS 


This appendix lists formulas for calculating execution times of machine 
language instructions. Instructions are listed by hexadecimal operation 
code and assembler mnemonic. In most cases, times are dependent on the 
type of addressing (direct/indirect) used for instruction operands. 
Formulas for each of the addressing combinations possible are listed, 
where: A refers to operand |] with direct addressing, B to operand 2 
with direct addressing, (A) to operand | with indirect addressing, and 
(B) to operand 2 with indirect addressing. A legend of meanings of 
symbols used fn the formulas is at the end of this appendix. 
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Mnemonic A-B (A) -B A- (B) (A) - (B) 

SBA M] + 6M9 M,) + 6M2 

RBA M] + 6M2 My} + 642 

TST M1+3M2 My + 4Mo My + 4M9 M) + 5M9 

(Unprivileged (Unprivileged (Privileged (Privileged 
Bit Set) Bit Not Set) Bit Set) Bit Not Set) 

CTB M] + 3M2 (Unprivi leged) My) + 4M2 (Privileged) 

SR My + 2M9 

SCN My + 7M2 My; + 8M9 

(Processors 4-7). (Processors 0-3) 
RCN My) + 7M2 My + 8M2 
(Processors 4-7) (Processors 0-3) 
SPM My) + 3M2 M) + 6Mo 
(Unprivileged Mode) (Privileged Mode) 
RPM | My) + 3Mo | My + 6M9 
(Unprivileged Mode) (Privileged Mode) 

MOVR M] +M2 2M) 2M] + Mo 3M] 

CMPR My + Mo 2My 2M) + 2Mo 3M) + Mo | 
ADDR My + Mo 2M 3M) + Mo 4M] 

SUBR My + Mo 2M 3M) + Mp hoy 

INVR My] + M2 2M] 2M] + M2 3M] 

ANDR My] + Mo 2M] 3M) + Mo 4M] 

EORR My) + Mo 2M] 3M) + Mo 4M] 

IORR M) + M2 2M) 3M) + Mg hoy 

MPYR 2M] +7Mo+K] 3M] +6M2+K] SM) +5Mo+K] 6M) +4M9+K] 
DIVR M]+5Mo+K2 92M] +4M9+Ko 5M1+3Ma+K2 6M) +2Mo+Ko 
CSTR M] + Mo 2M] 

CLDR My] + M2 2M 

LLSR M) + M2 2M) + M2 
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Code 


2D 


Ze 


22 


30 
5 
32 
33 
34 
35 
36 
37 


38. 


39 
3A 
3B 
3C 
3D 
3E 
3F 
40 
I] 
42 
43 
hy 
4s 
46 


Mnemonic 


LRSR 
RLSR 
ARSR 


LOD I 


CMP 


ADDI 
SUBI 
INV 
ANDI 
EOR| 
IORI 
MPY | 
DIvI 
PSTR 
SHFK 
LLDR 
LRDR 
RLDR 
ARDR 
SRZF 
SRZB 
SRNF 
SRNB 
SRPF 
SRPB 
SRMF 


My) + 2M9 2M, + 2Mo 
My + Mo 2M] + Mo 


My + 3M. 2M, + 3Mo 


My + 2Mo 
M) + 2Mo 
My + 2M9 


2M, +8MoKy 


My +6Mo4+Ko 


My + Mo 
See special formula at end 


My + 5Mo . 2M) + 5M> 
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A- (8) — (A)-(B) 


2M) + Mo 
2M, + 2Mo 
3M) + Mo 
3M) + Mo 
2M, + Mo 
3M] + Mo 
3M) + Mo 
3M) + Mo 
5M] +5Mo+Ky 
5M) +3Mo+Ko 


— 2My 


<x a) Note A: M)+Mo if shift count=0 
~My + 5SMo Ff w 2M) + SMofo 
rw rw) ‘ . 
9 O Note B: 2M;+Moif shift count=0 
My + 5Mg (= 2M) + 5M2 (7 : 
Vy oO 
My + SM 7% 2M).+ 5Mo/™ 
M) + 3M9 
My, + 3M9 
M) + 3Mo 
My + 3M9 | M; + Mo if skip not taken 
My + 3M9 
My + 3Mo 
My + 3Mo 
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en Mnemonic A-B (A) -B A-(B) (A) -(B) 
47 SRMB My, + 3M 
48 SCTF My) + 3Mo 
4g SCFF My) + 3M9 
My + Mo if skip not taken 

hA SCTB My + 3M2 
4B SCFB My + 3M9 
ke LLSI My + M2 
kD LRS| My) + 2M2 
KE RLS| My) + MQ 
he ARS| My + 3M2 
50 ZADK 
5] CMPK 
52 ADDK 
53 SUBK 
5h MOVX 
55 CMPX See special formulas 

at end 
56 TRNX 
57s EDTX 
58 PAKX 
59 UNPX 
5A MOVL 
5B MPYK 
5C LLDI M, + 5Mo 
5D LRDI My, + 5Mo 
SE ae My + 5M My + Mg if shift count=0 
5F ARD I My + 5Mo 
60 MOVM 5M 6M 6M, 7M) 
61 CMPM 5M, + Mo 6M) + Mo 6M) + Mo 7M, + Mo 
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Hex 
Code Mnemonic — A-B (A) -B A~(B) (A) -(B) 
62 =ADDM OGM 7M) 7My 8M, 

63 SUBM 6M, ™, 7M 8M, 

64 INVM 5M) 6M 6M) 7M 

65 ANDM OGM 7) ™, 8M 

66  — EORM 6M, My 7™M 8M) 

67 10RM 6M) 7M, 7M, 8M, 

68 MPYM BM) +4Mo+K, 9Myt4Mot+K, © OM, +4Mo+Ky 10M) +4Mo+K) 
69 DIVM 8M] +2Mo+Ky 9M) +2Mo+Ky 9M) +2Mo+Ky 10M) +2Mo+K» 
6A MOVB 5M} 6M, 6M 7™My 

6B CBYM BM; + My 6My + My 6M, + Mo 7M, + My 

6c TONR My) + 2M, 2M, + 2M5 3M, + 2M, 4M) + 2M, 
6D RONR My) + 3M) 3M, + 2My 3M, + 3M, 5M, + 2M» 
6E TOFR My + 2M. 2M) + 2My 3M, + 2M, 4M) + 2M> 
6F ROFR My) + 3M.  -3My + 2Mo 3M) + 3M5 5M, + 2M> 
70. LODT 1M OMY 6M, 7M 

7] CMPT 3.5M)+Mo (avg.) 4.5M)+Mo (avg.) 5M)+Mo(avg.) 6M)+Mo (avg.) 
72 ADDT AM) +My SM) + Mo 8M, OM 

73 SUBT WM) +My 5M, + Mg 8M, 9M 

7c DIVK See special formula at end. 

AO LOD 3M] 4M hey 5M 

Al CMP 3M, LM AM) + My 5M) + Mo 
A2 ADD 3My 4M 5M | 6My 

A3 SUB 3M AM 5M) 6M) 

Au INV 3M) My MM) My 

A5 —AND 3M 4M 5M) 6M) 

A6 EOR 3My 4M 5M) 6My 

A7 1OR. 3My 4M | 5M 6M} 

A8 MPY AM +6Mo+K, 5M) +6M9+Ky 7M) +4Mo+K) 8M +4Mo+Ky 
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Code Mnemonic 


AQ 
AA 
AA 
AB 
AB 
BO 
Bl 
B2 
B3 
B4 
B5 
B6 
B7 
B8 
B9 
BA 
BB 
BC 
BD 
BE 


BF 


DIV 


CVB 


CVBT 


CVD 


CVDT 


LODD 


CMPD 


ADDD 


SUBD 


INVD 


ANDD 


EORD 


!ORD 


MPYD 


DIVD 


SF 


SB 


SBIT 


RBIT 


TBIT 


IBIT 


A-B 


3M) +4M5+Ky AM) +4Mo+Ko 


4M) +46M> 


6M 


2M) 
2M 
2M) 
2M) 
2M 
2My 


2M) 


+ 


+ 


+ 


K3 


2M) + Mo 


3M) +7My+Ky 


2M, +5Mo+Ko 


My + 2M, 


My + 2M5 


AM, 


4M 


3M] + Mo 


AM, 


FOR MEMOREX 


(A) -B A-(B) 
7M] +2M9+Ko 
5M) +46M>5 
6M, +90M> 
7M, + Kg 
9M) +38Mo+K3 
3M 
3M, + Mo 
4M, 
4M, 
3M 
AM, 
4M 
AM, 
6M) +4M5+K, 
6M) +2Mo+Ky 
5My 
5M) 
4M) + Mo 
5My 
C-6 
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(a)=(B) 


8M) +2Mo+K» 
7M) +90M5 


10M) +38M9+K3 
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Hex 
Code Mnemonic A-B (A) -B A-(B) (A) -(B) 
EO BRZ 2M, 3M) 3M, 4M 
EI BRN 2M, 3M, | 3M) AM 
E2 BOF 2M, 3M, 
E3 BON 2M, 3M, 2M 
if jump 
E4 BAI 2M 3M hi SM not. 
. ] ] ] ] 
taken 
E5 BA2 2M, 3M, 4M oM, 
E6 BS] (2M, 3M, 4M 5M, 
E7 BS2 2M, 3M, 4M aM, 
E8 ss BCT 2M, 3M, 
E9 BCF 2M, 3M, 
EA BSR 2M, + Mo 3M, + Mo 3M) AM 
EB BR My + My 2M) 
EC BCH 2M, 3M, 
ED B 2M, 3M, 
EE NOP M, + Mo M) + My M) + My M, + M, 
EF BCM My + Mo 
FO RDX My + 3M, 
FO WRX My + 4M, 
FI $10 
F2 DIO 
F3 RDC 
F4 WRC My + 2Mo 
FS INP M + aM, 2M, + Mo 
F6 OUT My + 4M, 2M, + 4M, 
F7 LODB 3M, AM 4M SM, 
F8 STOB 3M) 4M, 4M, aM, 
F9 CBY 3M) + M, 4M, + Mo 4M, + Mo 5M + Mo 


FOR MEMOREX INTERNAL USE ONLY 


fee Mnemonic A-B (A) -B A-(B) (A) -(B) 
FA STO). . 3M, 4M, 4M, 5My 
FB STOT | My My 6My 7M] 
FD RRO 3M, + 3Mo 4M, + 3M 
FD WRO 3M, + 3M 4M) + 2M» 
FE RAR 2M, + 3M 3M, + 3M> 
FE WAR 2M, + 3M 3M] + 3My 
FF SAR 12M) +22M5 
FF RSAR 12M, +24M5 


C-8 -2999.001 


FOR MEMOREX INTERNAL USE ONLY. 


SPECIAL FORMULAS 


ZADK = L2<L1 — (6F4L 119) M]+[11+(104+6L1-2L2) ig] Mo 
L2>L1 [+(L2+3L1) ig]M)+[15+(10+L2+3L1) ig] Mz 
CMPK =-L2<L1 (5+igt2i gth2+L1)My+(3+5+i gt3L1) Mo 
| L2>L1 (642i gtL2+L1)My+(8+3L2) Mo 
ADDK = L2<L] (64+3L1*ig)M,+[10+(10+4L1-2L2) ig]Mg 
L2>L1 [6+(L2+2L1) ig]Mp+[14+(10+2L1+L2) ig]M2 


if recomplement add: 
(3L1+1)Mj+(SL1+7) Mo 


SUBK same as ADDK 


MOVX  L2>L1 — (5+L1) My +3Mo (word move)* 
(6+2L1)My+(2+i7)Mo (byte move) * 
L2<L] (5+L2+L.1)M]+3Mo 
CMPX L2>L1 (4+L2)M)+(3+L2+.5L1) Mo (word compare) * 
| (44+2L2)M)+(3+2L2+L1) Mo (byte compare) * 
L2<L] (4+L1)My+(3+L1+.5L2)Mo (word compare) * 
(442L1)M)+(3+2L1+L2) Mo (byte compare) * 
TRNX (7+3L1)M)+(4+L1) Mo 


EDTX Numeric Edit (L240) 
(A+ Lp th 24h 1)My+(1343C ,+6C gC 3+2Cy,+3Ce 
#7.5C¢)Motl(1.5LI+1)M,+(5.5L1-1.517 
+igt9)Mglig 
Alpha Edit (12=0) 


(tL t2C,+Cy)My + (5420, 4+C3+2Cy) M2 


C-9 2999 .001 


FOR MEMOREX INTERNAL USE ONLY 


PAKX 4M) +7Mo+[ (3L1+1g)My]+(1OL1+ig-1)Mg] ig 

UNPX WM) +7Mo+[(LI+L2*ig)M)+(5.5L1-1.5i7+i6+9)Molig 

MOVL (5+L2)M)+2M>5 (word move) * 
(5+2L2)M]+2M> (byte move)* 

SHFK [3+(7L2+2i 1542116) ig]My 


+[7+(8+15L2- (5+i} 5) ip o+(3+2i]5+71 12) i) 4) 1g]M2 


MPYK [7+2N7+4Lo+((20L)+2L9-8)Nco+10L,-5)NoIMy 


+ [16+2M7+((27.5L)-7.75)No+13.75L1-6.87) NgIMo 


DIVK [15+24L) (Lo-Ly)+2L9 (Lo-L1-5) 1M) 


+ [35+52L] (Lo-L1)-6L1-20L2]M2 


C-10 — -2999.001 - 


FOR MEMOREX INTERNAL USE ONLY 


LEGEND 


M|= Memory reference cycle time 
Mo™ Non-memory reference cycle time 
Kj= (iytigtigtint2is)Mo 


Ko= ((5S1+i,+i5)Mo) io 


K3= [442 1o#t 1743178 (15#161] 9-129) M2 


LI 
L2 lengths as specified in the machine language 


Lm=length of edit mask including new fill. 
characters, characters to be inserted and al] 
the edit operators. 


C;=count of source characters (digits) moved to 
result via the MC or MCS operators. 


Co=count of source digits suppressed by fill. 
C3=count of IC and ICS operators in edit mask. 


Cy=count of mask characters inserted or suppressed 
in result via 10 and ICS operators. 


Co=count of SSD and SFI operators in edit mask. 


Cg=count of ISG operators in edit mask. . 


ig = 0 If A=0 


a 


f A and B have like signs 
f A and B have unlike signs 


i 
1 i 
iy = number of one-bits in smaller of |A] or [B | 
is = 16 - bit# of MSB in smaller of |A| or |B{ 


ig = number of non-zero digits unpacked 


C-1] 2999 .001 


ig 


i10 
iy 


12 


ar 


FOR MEMOREX INTERNAL USE ONLY 


0 if LI ts even 


l 


if Ll is odd 


0 if L2=0 


1 


if 1240 


0 if LI=0 


1 


if LI #0 
sign extended shift count from 6th byte of instruction 


smaller of [in| and (2L-1) 


0 if i;2=0 

1 if i240 

0 if i71> 0 left shift 
1 if i;,< 0 right shift 


0 if result of shift#0 
1 if result of shift=0 


number of one-bits in [|B | 


O if ij7 = 0 
| if ij7 #0 


0 if single precision (CVD) 
1 if double precision (CVDT) 


bit position of MSB in B 
1 if N7< Lg 
0 if N7 = Lo 


number of bytes of leading zeros in operand B field 
(multiplier field). (Nz >L}y) 


Lo-Nz-1 


2999 .001 


